mybatis模糊查询使用频率很高,下面重点详解mybatis模糊查询的3种主流方式写法语句。
第一种:直接将封装好的条件传给 sql 语句
1.增加配置
<!-- 根据姓名查询学生信息--> <select id="selectStuByName" resultType="com.mikechen.mybatis.domain.Student"> select * from student where name like #{name} </select>
2.调用接口
/** * 根据姓名模糊查询学生信息 * @param name 学生名字 * @return */ public List<Student> selectStuByName(@Param("name") String name);
3.代码实现
@Test public void testLikeOne() { // 读取配置文件到数据流 InputStream stream = Student.class.getClassLoader().getResourceAsStream("mybatis-config.xml"); // 创建SqlSessionFactory SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(stream); //创建SqlSession SqlSession sqlSession = sqlSessionFactory.openSession(); //获取StudentMapper StudentMapper mapper = sqlSession.getMapper(StudentMapper.class); //执行查询语句 String name = "%小%"; List<Student> students = mapper.selectStuByName(name); }
第二种:使用字符串连接符 ${} 来实现
1.增加配置
根据姓名查询学生信息,如下所示:
<select id="selectStuByName" resultType="com.mikechen.mybatis.domain.Student"> select * from student where name like "%" #{name} "%" </select>
2.代码实现
@Test public void testLike() { //读取配置文件到数据流 InputStream stream = Student.class.getClassLoader().getResourceAsStream("mybatis-config.xml"); //创建SqlSessionFactory SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(stream); //创建SqlSession SqlSession sqlSession = sqlSessionFactory.openSession(); //获取StudentMapper StudentMapper mapper = sqlSession.getMapper(StudentMapper.class); //执行查询语句 String name = "小"; List<Student> students = mapper.selectStuByName(name); }
1.增加配置
<select id="findByName" parameterType="string" resultType="User"> select * from t_user where name like concat(#{name},'%') </select>
2.代码实现
@Test public void testFindLike() throws IOException{ SqlSession session = MybatisUtil.getSqlSession(); List<User> list = session.selectList("cn.mikechen.vo.UserMapper.findByName","张"); for(User u:list){ System.out.println(u); } session.close(); }
mikechen睿哥
mikechen睿哥,十余年BAT架构经验,资深技术专家,就职于阿里、淘宝、百度等一线互联网大厂。
关注「mikechen」公众号,获取更多技术干货!
后台回复【面试】即可获取《史上最全阿里Java面试题总结》,后台回复【架构】,即可获取《阿里架构师进阶专题全部合集》