MyBatis中sqlId如何进行动态SQL

avatar
作者
猴君
阅读量:0

在 MyBatis 中,可以使用 <if> 标签来实现动态 SQL。以下是一个简单的示例:

首先,创建一个实体类 User

public class User {     private Integer id;     private String name;     private Integer age;     // 省略 getter 和 setter 方法 } 

然后,在 MyBatis 的映射文件中编写动态 SQL:

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.example.mapper.UserMapper">     <select id="findUsers" parameterType="com.example.entity.User" resultType="com.example.entity.User">         SELECT * FROM user         <where>             <if test="id != null">                 AND id = #{id}             </if>             <if test="name != null and name != ''">                 AND name = #{name}             </if>             <if test="age != null">                 AND age = #{age}             </if>         </where>     </select> </mapper> 

在这个示例中,我们使用 <where> 标签包裹动态 SQL,并使用 <if> 标签根据实体类的属性值来决定是否添加相应的条件。注意,<where> 标签会自动处理 ANDWHERE 关键字,所以当没有条件满足时,不会生成多余的 AND 关键字。

接下来,创建一个对应的 Mapper 接口:

package com.example.mapper;  import com.example.entity.User; import java.util.List;  public interface UserMapper {     List<User> findUsers(User user); } 

最后,在你的业务逻辑中调用这个动态 SQL:

@Service public class UserService {     @Autowired     private UserMapper userMapper;      public List<User> getUsers(User user) {         return userMapper.findUsers(user);     } } 

这样,你就可以根据传入的实体类参数动态生成 SQL 查询语句了。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!