【时快讯】一起聊聊MySQL动态SQL拼接

时间:2022-12-01 18:04:14       来源:转载
本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于动态SQL拼接的相关内容,实际业务开发中,我们的SQL语句通常是动态拼接而成的,比如条件搜索功能的SQL语句等等,下面一起来看一下,希望对大家有帮助。

推荐学习:mysql视频教程


(资料图)

一、动态sql拼接

目标

能够使用mybatis的标签实现动态SQL拼接

分析

我们在前边的学习过程中,使用的SQL语句都非常简单。而在实际业务开发中,我们的SQL语句通常是动态拼接而成的,比如:条件搜索功能的SQL语句。

# 提供了一个功能:用户可以在页面上根据username、sex、address进行搜索# 用户输入的搜索条件:可以是一个条件,也可能是两个、三个# 只输入一个条件:姓名是"王"SELECT * FROM USER WHERE username LIKE "%王%"# 只输入一个条件:性别是“男”SELECT * FROM USER WHERE sex = "男"# 输入两个条件:姓名“王”,性别“男”SELECT * FROM USER WHERE username LIKE "%王%" AND sex = "男"# 输入三个条件:姓名“王”,性别“男”,地址“北京”SELECT * FROM USER WHERE username LIKE "%王%" AND sex = "男" AND address LIKE "%北京%";
登录后复制

在Mybatis中,SQL语句是写在映射配置的XML文件中的。Mybatis提供了一些XML的标签,用来实现动态SQL的拼接。

常用的标签有:

:用来进行判断,相当于Java里的if判断:通常和if配合,用来代替SQL语句中的where 1=1:用来遍历一个集合,把集合里的内容拼接到SQL语句中。例如拼接:in (value1, value2, ...):用于定义sql片段,达到重复使用的目的

讲解

1. 准备Mybatis环境

创建java项目,导入jar包;准备JavaBean

创建映射器接口UserDao

创建映射配置文件UserDao.xml

创建全局配置文件SqlMapConfig.xml

创建日志配置文件log4j.properties

2. 标签:

语法介绍
SQL语句内容, 如果判断为true,这里的SQL语句就会进行拼接
登录后复制
使用示例

根据用户的名称和性别搜索用户信息。把搜索条件放到User对象里,传递给SQL语句

映射器接口UserDao上加方法

package com.demo.dao;import com.demo.domain.User;import java.util.List;public interface UserDao {    /**     * 根据username和sex搜索用户     * @param user 封装了搜索条件的User对象     * @return 搜索的结果     */    List search1(User user);}
登录后复制

映射文件UserDao.xml里配置statement

        
登录后复制

功能测试,在测试类里加测试方法

package com.demo;import com.demo.dao.UserDao;import com.demo.domain.User;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import org.junit.After;import org.junit.Before;import org.junit.Test;import java.io.IOException;import java.io.InputStream;import java.util.List;public class SqlTest {    private UserDao userDao;    private SqlSession session;    private InputStream is;    /**     * 要求:根据username和sex搜索用户     *      搜索条件放到user对象里     */    @Test    public void testSearch(){        User user = new User();        // user.setUsername("王");        // user.setSex("男");        List userList = userDao.search1(user);        userList.forEach(System.out::println);    }    @Before    public void init() throws IOException {        //1. 读取全局配置文件        is = Resources.getResourceAsStream("SqlMapConfig.xml");        //2. 得到一个SqlSession对象        SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);        session = factory.openSession();        userDao = session.getMapper(UserDao.class);    }    @After    public void destroy() throws IOException {        session.close();        is.close();    }}
登录后复制

3. 标签

语法介绍

在刚刚的练习的SQL语句中,我们写了where 1=1。如果不写的话,SQL语句会出现语法错误。Mybatis提供了一种代替where 1=1的技术:标签。

代码示例

把上一章节的实现代码进行优化,使用标签代替where 1=1

映射器UserDao的search1方法:已有,不用修改

/** * 根据username和sex搜索用户 * @param user 封装了搜索条件的User对象 * @return 搜索的结果 */List search1(User user);
登录后复制

在映射文件UserDao.xml里修改SQL语句

登录后复制

在测试类里进行功能测试:测试方法不需要修改

@Testpublic void testSearch(){    User user = new User();    // user.setUsername("王");    // user.setSex("男");    List userList = userDao.search1(user);    userList.forEach(System.out::println);}
登录后复制

4. 标签

语法介绍

foreach标签,通常用于循环遍历一个集合,把集合的内容拼接到SQL语句中。例如,我们要根据多个id查询用户信息,SQL语句:

select * from user where id = 1 or id = 2 or id = 3;select * from user where id in (1, 2, 3);
登录后复制

假如我们传参了id的集合,那么在映射文件中,如何遍历集合拼接SQL语句呢?可以使用foreach标签实现。

    #{id}
登录后复制
使用示例

有搜索条件类QueryVO如下:

package com.itheima.domain;public class QueryVO {    private Integer[] ids;    public Integer[] getIds() {        return ids;    }    public void setIds(Integer[] ids) {        this.ids = ids;    }}
登录后复制

在映射器UserDao里加方法

/**     * QueryVO里有一个Integer[] ids     * 要求:根据ids查询对应的用户列表     */List search2(QueryVO vo);
登录后复制

在映射文件UserDao.xml里配置statement

    
登录后复制

功能测试

@Test    public void testSearch2(){        QueryVO vo = new QueryVO();        vo.setIds(new Integer[]{41,42,43,44,45});        List userList = userDao.search2(vo);        userList.forEach(System.out::println);    }
登录后复制

5. 标签

在映射文件中,我们发现有很多SQL片段是重复的,比如:select * from user。Mybatis提供了一个标签,把重复的SQL片段抽取出来,可以重复使用。

语法介绍

在映射文件中定义SQL片段:

sql语句片段
登录后复制

在映射文件中引用SQL片段:

登录后复制
使用示例

在查询用户的SQL中,需要重复编写:select * from user。把这部分SQL提取成SQL片段以重复使用

要求:QueryVO里有ids,user对象。根据条件进行搜索

修改QueryVO,增加成员变量user

package com.itheima.domain;/** * @author liuyp * @date 2021/09/07 */public class QueryVO {    private Integer[] ids;    private User user;    //get/set方法……}
登录后复制

在映射器UserDao里加方法

/**     * 动态SQL拼接的综合应用:if、where、foreach     * 要求:QueryVo里有ids、username、sex值,根据这些值进行搜索     */    List search3(QueryVO vo);
登录后复制

在映射文件UserDao.xml里配置statement

select * from user                        and username like "%"#{user.username}"%"                            and sex = #{user.sex}            
登录后复制

在测试类里加测试方法

@Test    public void testSearch3(){        QueryVO vo = new QueryVO();        vo.setIds(new Integer[]{41,42,43,44,45});        // User user = new User();        // user.setUsername("王");        // user.setSex("男");        // vo.setUser(user);        List userList = userDao.search3(vo);        userList.forEach(System.out::println);    }
登录后复制

推荐学习:mysql视频教程

以上就是一起聊聊MySQL动态SQL拼接的详细内容,更多请关注php中文网其它相关文章!

关键词: 配置文件 测试方法 功能测试