mybatis学习之模糊查询用户例子

本文介绍了如何在MyBatis中实现用户信息的模糊查询,包括配置数据库映射文件(User.xml)以支持模糊搜索功能,并提供了具体的代码示例。此外还讨论了使用${}

上接上一篇博客

1、配置数据库映射文件(User.xml)

在其中加入如下代码:

   <!--
     根据用户名称模糊查询用户信息
     注意:此处resultType不管单条多条结果记录,都为所映射成的java对象
     ${}表示拼接sql串,将接受到的参数的内容不加任何修饰拼接在sql语句中
     使用${}符号可能会引起sql注入问题
     -->
    <select id="findUserByName" parameterType="String" resultType="pojo.User">
        SELECT * FROM USER WHERE username LIKE '%${value}%'
    </select>


2、编写程序

//根据用户的名称模糊查询用户信息
    @Test
    public void findUserByNameTest(){
        //mybatis配置文件
        String resource = "SqlMapConfig.xml";
        SqlSession sqlSession = null;
        try {
            InputStream inputStream = Resources.getResourceAsStream(resource);
            //创建会话工厂,传入mybatis的配置信息
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            //通过工厂得到SqlSession
            sqlSession = sqlSessionFactory.openSession();
            //通过SqlSession来操作数据库
            //List中的User泛型,和resultType中指定的类型一致
            List<User> list = sqlSession.selectList("test.findUserByName","测试");
            System.out.print(list);
        }catch (IOException e){
            e.printStackTrace();
        }finally {
            //释放资源
            sqlSession.close();
        }
    }

运行后如下图:



在此处要注意的几点问题:

返回多条记录和返回单调记录,在映射文件中配置resultType类型仍为该表的po类,在后面的接受参数时,直接定义一个泛型为该类的List集合来接收

模糊查询提到了一个占位符的另外一种表现形式,即${},这样是不加任何修饰直接插入,但这样使用可能会引起sql注入的问题,比如你要插入一串now()函数,程序运 运行sql会将''也算进去执行。

### MyBatis 实现用户模糊查询的方法 在 MyBatis 中实现用户相关的模糊查询主要依赖于预编译 SQL 和 `#{} `占位符来防止 SQL 注入攻击。下面提供了一个具体的例子说明如何配置 XML 映射文件以及 Java 测试类来进行基于用户名的模糊匹配。 #### 使用 XML 配置映射文件 对于用户表中的字段`username`, 如果想要执行类似于 'LIKE %value%' 的操作, 应当这样编写SQL语句: ```xml <select id="selectUserByUsernameLike" parameterType="string" resultType="com.example.User"> SELECT * FROM users WHERE username LIKE CONCAT('%', #{username}, '%') </select> ``` 这段代码定义了一个名为 `selectUserByUsernameLike` 的查询接口,它接受字符串类型的参数作为输入,并返回一系列 User 对象[^1]。 #### 编写对应的 Mapper 接口 接着,在相应的 Mapper 接口中声明此方法: ```java public interface UserMapper { List<User> selectUserByUsernameLike(@Param("username") String username); } ``` 这里使用了 `@Param` 注解指定传入参数的名字以便与XML中使用的名称相匹配[^3]。 #### 创建单元测试验证功能 最后可以创建 JUnit 测试案例以确保上述逻辑正常工作: ```java @Test public void testSelectUsersByName() { try (SqlSession session = MyBatisUtil.getSqlSession()) { UserMapper mapper = session.getMapper(UserMapper.class); // 构造模糊条件 String pattern = "%张%"; // 执行查询并打印结果 List<User> userList = mapper.selectUserByUsernameLike(pattern); userList.forEach(System.out::println); } } ``` 这种方法不仅适用于用户的姓名属性,也可以应用于其他任何适合做模糊搜索的数据列。通过这种方式能够有效地保护应用程序免受潜在的安全威胁的同时满足业务上的灵活检索需求[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值