MyBatis模糊查询详解(3种主流写法语句)

MyBatis模糊查询详解(3种主流写法语句)-mikechen

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);

}

 

第三种:使用 mysql 的字符串拼接函数实现

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面试题总结》,后台回复架构,即可获取《阿里架构师进阶专题全部合集

评论交流
    说说你的看法