MyBatis 学习总结(七)——模糊查询

模糊查询


用到的实体类

public class User {

    private Integer id;
    private String name;
    private int age;

    //省略其它必备的基本方法
    ......

利用 MyBatis 进行对表的模糊查询,其实很简单,主要是在普通查询的基础上加多一个查询的条件参数的封装类。

UserCondition.java

public class UserCondition {
    private String name;
    private int minAge;
    private int maxAge;

    //注意:主要用于判断模糊查询的条件是否为空的情况
    public String getName() {
        if (name != null) {
            return "%" + name + "%";
        } else {
            return "%%";
        }
    }
    //省略其它基本方法
    ......

配置 UserMapper.ml 的映射文件中加入

    //使用模糊查询的 SQL 语句 传入参数类型为 UserCondition
    <select id="selectUser" parameterType="UserCondition"
        resultType="User">
        SELECT * FROM users WHERE name LIKE #{name} AND age BETWEEN
        #{minAge} AND #{maxAge}
    </select>
</mapper>

结果自行测试。

MyBatis中,可以使用XML配置文件来实现模糊查询。在XML映射文件中,可以使用两种方式定义参数进行模糊查询。 第一种方式是使用#定义参数。首先,在持久层接口中添加一个根据名字内容模糊查询的方法,方法名为`findByNameLike`,参数类型为`String`,返回类型为`List<User>`。然后,在XML映射文件中添加一个`select`标签,设置`id`为`findByNameLike`,`parameterType`为`string`,`resultType`为`com.mybatisstudy.pojo.User`,并在`select`标签内编写SQL语句,使用`#{name}`来引用参数。具体代码如下所示: ```xml <!-- 使用#定义参数 --> <select id="findByNameLike" parameterType="string" resultType="com.mybatisstudy.pojo.User"> select * from user where username like #{name} </select> ``` 第二种方式是使用$定义参数。在XML映射文件中,将`select`标签内的SQL语句修改为使用`${value}`来引用参数,并在持久层接口中的方法参数前不加`%`。具体代码如下所示: ```xml <!-- 使用$定义参数 --> <select id="findByNameLike" resultType="com.mybatisstudy.pojo.User" parameterType="string"> select * from user where username like '%${value}%' </select> ``` 以上是在XML映射文件中实现模糊查询的两种方式。你可以根据具体需求选择其中一种方式来实现模糊查询。 #### 引用[.reference_title] - *1* *2* *3* [Mybatis模糊查询——三种定义参数方法和聚合查询、主键回填](https://blog.csdn.net/qq_53317005/article/details/129762660)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值