iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL——动态SQL拼接
  • 208
分享到

MySQL——动态SQL拼接

sqlmysql 2023-09-23 08:09:58 208人浏览 八月长安
摘要

一、动态sql拼接 目标 能够使用mybatis的标签实现动态SQL拼接 分析 ​ 我们在前边的学习过程中,使用的SQL语句都非常简单。而在实际业务开发中,我们的SQL语句通常是动态拼接而成的,比如:

一、动态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环境
  1. 创建java项目,导入jar包;准备JavaBean
  2. 创建映射器接口UserDao
  3. 创建映射配置文件UserDao.xml
  4. 创建全局配置文件SqlMapConfig.xml
  5. 创建日志配置文件log4j.properties
2. 标签:
语法介绍
<if test="判断条件,使用OGNL表达式进行判断">SQL语句内容, 如果判断为true,这里的SQL语句就会进行拼接if>
使用示例
  • 根据用户的名称和性别搜索用户信息。把搜索条件放到User对象里,传递给SQL语句
  1. 映射器接口UserDao上加方法
package com.demo.dao;import com.demo.domain.User;import java.util.List;public interface UserDao {        List<User> search1(User user);}
  1. 映射文件UserDao.xml里配置statement
DOCTYPE mapper        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"        "Http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.itheima.dao.UserDao">        <select id="search1" resultType="User">        select * from user where 1=1        <if test="username != null and username.length()>0">            and username like "%"#{username}"%"        if>        <if test="sex != null and sex.length()>0">            and sex = #{sex}        if>    select>mapper>
  1. 功能测试,在测试类里加测试方法
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;        @Test    public void testSearch(){        User user = new User();        // user.setUsername("王");        // user.setSex("男");        List<User> 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

  1. 映射器UserDao的search1方法:已有,不用修改
List<User> search1(User user);
  1. 在映射文件UserDao.xml里修改SQL语句
<select id="search1" resultType="User">    select * from user    <where>        <if test="username != null and username.length()>0">            and username like "%"#{username}"%"        if>        <if test="sex != null and sex.length()>0">            and sex = #{sex}        if>    where>select>
  1. 在测试类里进行功能测试:测试方法不需要修改
@Testpublic void testSearch(){    User user = new User();    // user.setUsername("王");    // user.setSex("男");    List<User> 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标签实现。

<foreach collection="" open="id in(" item="id" separator="," close=")">    #{id}foreach>
使用示例
  1. 有搜索条件类QueryVO如下:
package com.itheima.domain;public class QueryVO {    private Integer[] ids;    public Integer[] getIds() {        return ids;    }    public void setIds(Integer[] ids) {        this.ids = ids;    }}
  1. 在映射器UserDao里加方法
List<User> search2(QueryVO vo);
  1. 在映射文件UserDao.xml里配置statement
        <select id="search2" resultType="User">                select * from user where        <foreach collection="ids" open="id in(" item="id" separator="," close=")">            #{id}        foreach>    select>
  1. 功能测试
    @Test    public void testSearch2(){        QueryVO vo = new QueryVO();        vo.setIds(new Integer[]{41,42,43,44,45});        List<User> userList = userDao.search2(vo);        userList.forEach(System.out::println);    }
5. 标签

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

语法介绍

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

<sql id="唯一标识">sql语句片段sql>

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

<include refid="sql片段的id">include>
使用示例

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

  • 要求:QueryVO里有ids,user对象。根据条件进行搜索
  1. 修改QueryVO,增加成员变量user
package com.itheima.domain;public class QueryVO {    private Integer[] ids;    private User user;    //get/set方法……}
  1. 在映射器UserDao里加方法
        List<User> search3(QueryVO vo);
  1. 在映射文件UserDao.xml里配置statement
<select id="search3" resultType="User">        <include refid="selUser"/>    <where>        <if test="ids != null and ids.length > 0">            <foreach collection="ids" open="and id in(" item="id" separator="," close=")">                #{id}            foreach>        if>                <include refid="userCondition"/>    where>select><sql id="selUser">select * from usersql><sql id="userCondition">    <if test="user != null">        <if test="user.username != null and user.username.length() > 0">            and username like "%"#{user.username}"%"        if>        <if test="user.sex != null and user.sex.length() > 0">            and sex = #{user.sex}        if>    if>sql>
  1. 在测试类里加测试方法
    @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<User> userList = userDao.search3(vo);        userList.forEach(System.out::println);    }

来源地址:https://blog.csdn.net/yiqieruni/article/details/127617481

您可能感兴趣的文档:

--结束END--

本文标题: MySQL——动态SQL拼接

本文链接: https://www.lsjlt.com/news/416297.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL——动态SQL拼接
    一、动态sql拼接 目标 能够使用mybatis的标签实现动态SQL拼接 分析 ​ 我们在前边的学习过程中,使用的SQL语句都非常简单。而在实际业务开发中,我们的SQL语句通常是动态拼接而成的,比如:...
    99+
    2023-09-23
    sql mysql
  • MySQL动态SQL拼接怎么实现
    这篇“MySQL动态SQL拼接怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MyS...
    99+
    2022-12-16
    mysql sql
  • MySQL动态SQL拼接实例详解
    目录目标分析讲解1. 准备MyBATis环境2. <if>标签:3. <where>标签4. <foreach>标签 语法介绍5. <sql>标签总结目...
    99+
    2022-12-15
    mysql 动态拼接 mysql sql拼接 sql语句动态拼接
  • 动态SQL的拼接技巧有哪些
    这篇文章给大家介绍动态SQL的拼接技巧有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。常见的误解有: 1. 只用 ado.net ,无法进行动态 SQL 拼接。 ...
    99+
    2024-04-02
  • BIRT中怎么根据参数动态拼接SQL
    这篇文章的内容主要围绕BIRT中怎么根据参数动态拼接SQL进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!BIRT可以使用sql query来创建数据...
    99+
    2023-06-03
  • MyBatis中动态SQL拼接的方法是什么
    MyBatis中动态SQL拼接的方法主要是使用if、choose、when、otherwise等标签来实现动态条件拼接。具体来说,可...
    99+
    2024-04-08
    MyBatis
  • MySQL中如何实现SQL拼接
    在MySQL中,可以使用CONCAT()函数来实现SQL拼接。CONCAT()函数可以将多个字符串拼接在一起,例如:...
    99+
    2024-04-29
    MySQL SQL
  • vue 动态style 拼接宽度问题
    目录vue 动态style 拼接宽度vue style的用法1.基本用法2.采用数组形式3.使用数组的形式,设置多个属性4.使用设置一个变量的方法vue 动态style 拼接宽度 大...
    99+
    2024-04-02
  • vue$refs动态拼接获取值问题
    目录vue $refs动态拼接获取值vue $refs不能动态拼接问题项目需求:动态增减表单并验证总结vue $refs动态拼接获取值 div是循环 所以img 的ref是动态设置的...
    99+
    2023-01-28
    vue $refs vue动态拼接 动态拼接获取值
  • Android拼接如何实现动态对象
    这篇文章主要介绍了Android拼接如何实现动态对象的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Android拼接如何实现动态对象文章都会有所收获,下面我们一起来看看吧。1. 前言我们往往有些配置文件,当项目...
    99+
    2023-07-05
  • MybatisPlus实现多条件拼接动态查询
    1、前 言 最近在开发过程中,需要用 MybatisPlus 实现类似以下形式的 SQL 语句,动态拼接多个条件,进行查询。 select *from user_infowhere is_deleted = 0...
    99+
    2023-08-20
    mysql mybatis-plus spring boot
  • FluentMybatis实现mybatis动态sql拼装和fluent api语法
    目录开始第一个例子: Hello World新建演示用的数据库结构创建数据库表对应的Entity类运行测试来见证Fluent Mybatis的神奇配置spring bean定义使用J...
    99+
    2024-04-02
  • CPQuery中怎么拼接SQL
    CPQuery中怎么拼接SQL,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 CPQuery是什么? 看到博客的标题...
    99+
    2024-04-02
  • mybatis动态拼接实现有条件的插入
    目录动态拼接实现有条件的插入最近在做项目的时候遇到了一个很现实的问题mybatis插入语句mybatis插入语句一般都是这样写 动态拼接实现有条件的插入 最近在做项目的时候...
    99+
    2024-04-02
  • Android拼接实现动态对象方法详解
    目录1. 前言2. 动态选密钥3. 换肤上的使用4. 总结1. 前言 我们往往有些配置文件,当项目大的时候,一些配置文件或者一些判断逻辑就会变得复杂,会出现很多判断语句,我在想,能...
    99+
    2023-03-01
    Android拼接动态对象 Android 动态对象
  • sql拼接函数Group_concat()
    Group_concat 聚合函数 MySQL中,Group_concat() 函数 将一个分组中的指定元素(列或表达式)的值,拼接成一个字符串返回(用逗号分隔)。 Group_concat...
    99+
    2023-10-11
    sql mysql 数据库
  • SQL拼接在移动应用后端怎么实现
    在移动应用后端实现SQL拼接主要是通过使用相应的数据库操作库来实现。通常来说,后端开发语言比如Node.js、Java、PHP等都有...
    99+
    2024-04-29
    SQL
  • 关于vue src路径动态拼接的小知识
    目录vue src路径动态拼接第一种:本地添加第二种:从接口中获取图片的路径如何通过变量动态拼接urlvue src路径动态拼接 我是新手 今天写vue 的时候 让这个src 给我弄...
    99+
    2024-04-02
  • sql中如何进行拼接
    sql 中可使用多种方法进行字符串拼接,包括使用连接运算符 (+)、concat 函数、|| 运算符(oracle 和 mysql)、format 函数(sql server)和 stu...
    99+
    2024-05-09
    mysql oracle
  • FluentMybatis怎么实现mybatis动态sql拼装和fluent api语法
    这篇文章主要讲解了“FluentMybatis怎么实现mybatis动态sql拼装和fluent api语法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“FluentMybatis怎么实现m...
    99+
    2023-06-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作