SSM-动态SQL

ssm框架 Mybatis 

动态SQL主要是解决同一类SQL语句匹配不同的问题,举个栗子:

加入我要执行一个查询语句,但是是一个不确定的查询语句,可能会根据ID去查,如果ID没有就可能根据名字去查,或者说同时根据两个去查。那么这时候SQL语句就是不确定的,就要用到mybatis动态SQL语句了,同时Mybatis是基于OGNL表达式的。

动态SQL语句

  • if
  • where
  • choose
    • when
    • otherwise
  • set
  • trim
  • foreach
  • sql
  • include
  • bind

数据形式

id the_name flower
1 小明 小红花

if

if很简单的知道,就是判断条件的。
xml映射文件配置文件

<!--动态SQL if语句-->
<select id="query1" resultType="com.weno.pojo.Girl">
select * from Girl where
<if test= "the_name != null">
the_name = #{the_name}
</if>
<if test= "flower != null">
and flower = #{flower};
</if>
</select>
@Test
public void m006() {
SqlSession sqlSession = MybatisUtil.getSession(); GirlMapper mapper = sqlSession.getMapper(GirlMapper.class); Girl g= new Girl(); g.setName("小明");
// g.setFlower("小红花");
Girl girl=mapper.query1(g); sqlSession.commit();
sqlSession.close();
System.out.printf(girl.toString());
}

如果此时我们将小红花注释掉查看一下运行结果:

DEBUG [main] - ==>  Preparing: select * from Girl where the_name = ?
DEBUG [main] - ==> Parameters: 小明(String)
TRACE [main] - <== Columns: id, the_name, flower
TRACE [main] - <== Row: 1, 小明, 小红花
DEBUG [main] - <== Total: 1

在SQL语句中并没有加上flower语句。但是此时却有一个问题,如果the_namenull,而flower不为null,那么在SQL语句中岂不是多了一个and,变成了:

DEBUG [main] - ==>  Preparing: select * from Girl where and flower = ?;

这时候程序肯定报错,那么我们该如何处理呢?那么接下来说一下where标签。

where

任然使用上面的例子:

<select id="query2" resultType="com.weno.pojo.Girl">
select * from Girl
<where>
<if test="the_name != null">
and the_name = #{the_name}
</if>
<if test="flower != null">
and flower = #{flower}
</if>
</where>
</select>

这个跟上面的区别就是将where改成了<where>标签。
<where>在这里的作用就是当标签中有返回值时,就插入一个where,同时,如果标签是以ANDOR【不区分大小写】开头时,就剔除。

choose

choose语句有点类似Java中的switch,当有一个符合时,就选择那一个并跳出。
映射文件

<select id="query3" resultType="com.weno.pojo.Girl">
select * from Girl where
<choose>
<when test="id != null and id!=''">
id = #{id}
</when>
<when test="the_name != null and the_name != ''">
the_name = #{the_name}
</when> <otherwise>
flower = #{flower}
</otherwise>
</choose>
</select>

在这种情况下,如果id符合的话,就不会再考虑下面的了。

@Test
public void m008() {
SqlSession sqlSession = MybatisUtil.getSession();
GirlMapper mapper = sqlSession.getMapper(GirlMapper.class);
Girl g= new Girl();
g.setId(1);
g.setName("小明");
g.setFlower("小红花");
Girl girl=mapper.query3(g);
sqlSession.commit();
sqlSession.close();
System.out.printf(girl.toString());
}

SQL语句,在其中并没有选择the_name

DEBUG [main] - ==>  Preparing: select * from Girl where id = ?

set

set是一个更新数据的标签

<update id="update1">
update Girl set the_name=#{the_name},flower=#{flower} where id=#{id};
</update>

java代码:

@Test
public void m009() {
SqlSession sqlSession = MybatisUtil.getSession();
GirlMapper mapper = sqlSession.getMapper(GirlMapper.class);
Girl g= new Girl();
g.setId(1);
g.setName("小红");
// g.setFlower("小明花");
mapper.update1(g);
sqlSession.commit();
sqlSession.close();
}

如果此时这样执行,那么在数据库表里面,flower的数据即为null。假如此时,使用if标签

<update id="update2">
update Girl set
<if test="the_name != null and the_name != ''">
the_name=#{the_name},
</if>
<if test="flower != null and flower != ''">
flower=#{flower}
</if>
where id=#{id};
</update>

那么此时会出现一个问题,如果第一个符合,而第二个不符合,那么就会多一个,,此时使用<set>标签就可以解决这个问题

<update id="update3">
update Girl
<set>
<if test="the_name != null and the_name != ''">
the_name=#{the_name},
</if>
<if test="flower != null and flower != ''">
flower=#{flower},
</if>
</set>
where id=#{id};
</update>

<set>标签和<where>有点类似,在<set>标签中,如果结尾有逗号,就将逗号去除。

trim

<trim>就很神奇了,它既可以实现<set>的功能,也能够实现<where>的功能。

trim可以在前面增加和删除内容,也可在在后面也执行此操作。

<update id="query0">
<trim prefixOverrides="and | or">
<if test="the_name != null">
and the_name = #{the_name}
</if>
<if test="flower != null">
and flower = #{flower}
</if>
</trim>
</update>

去除第一个and或则是or

  • prefix:前缀      
  • prefixoverride:去掉第一个a
  • suffix:后缀  
  • suffixoverride:去掉最后一个

foreach

foreach 类似for循环。

改写我们用 foreach 来改写 select * from Girl where id in (1,2,3)

映射文件

    <!-- collection:指定输入对象中的集合属性,使用@Param("ids")指令名字
item:每次遍历生成的对象
open:开始遍历时的拼接字符串
close:结束时拼接的字符串
separator:遍历对象之间需要拼接的字符串
select * from Girl where id in (1,2,3) -->
<select id="queryByIDs" resultType="com.weno.pojo.Girl">
select * from Girl where
<foreach collection="ids" item="id" open="id in (" close=" ) " separator=",">
#{id}
</foreach>
</select>

sql

SQL片段主要是为了提高效率,可以讲动态SQL的判断部分独立处理,提高程序的复用率。

<!-- id是sql片段的标识,一定要唯一 -->
<sql id="sql_1">
<if test="the_name != null and the_name != ''">
the_name = #{the_name}
</if>
</sql>

注意:在SQL片段中,不要包括where

include

引用SQL片段,使用上面的例子

<select id="query2" resultType="com.weno.pojo.Girl">
select * from Girl
<where>
<include refid="sql_1"/>
<if test="flower != null">
and flower = #{flower}
</if>
</where>

就是如此简单。

bind

<bind>简单的来说,就是使值变成另外一个。

例如在模糊查询语句中要使传入的值变成%*%,那么就使用bind进行连接。

<select id="queryLikeByName" resultType="com.weno.pojo.Girl">
select * from Girl
<bind name="_name" value="'%'+the_name+'%'"/>
<!-- 如果the_name代表A,那么_name则代表%A% -->
where the_name like #{_name}
</select>

mybati的动态语句大概就这样了,如果学会了使用,那么毋庸置疑,可以大量的提高我们的效率。
不过更多的mybatis的使用,可以参考mybatis的 官方文档

妈耶,第一次写这么多的字,纪念一下!!

SSM-动态SQL的更多相关文章

  1. ssm动态sql语句

    1.将上面的元素分为四组来演示,分别为:[if,where,trim],[if,set,trim],[choose,when,otherwise],[foreach] ________________ ...

  2. SSM框架开发web项目系列(四) MyBatis之快速掌握动态SQL

    前言 通过前面的MyBatis部分学习,已经可以使用MyBatis独立构建一个数据库程序,基本的增删查改/关联查询等等都可以实现了.简单的单表操作和关联查询在实际开的业务流程中一定会有,但是可能只会占 ...

  3. 【JAVA - SSM】之MyBatis动态SQL

    动态SQL就是在SQL语句中添加一些标签,以完成某些逻辑.通常用到的动态SQL标签有<if>.<choose>.<where>.<trim>.<s ...

  4. Java SSM框架之MyBatis3(八)MyBatis之动态SQL

    前言: mybatis框架中最具特色的便是sql语句中的自定义,而动态sql的使用又使整个框架更加灵活. 创建User表 /*Table structure for table `user` */ D ...

  5. SSM框架之Mybatis(6)动态SQL

    Mybatis(6)动态SQL 1.动态SQL 出现原因:有些时候业务逻辑复杂时,我们的 SQL 是动态变化的,此时在前面的学习中我们的 SQL 就不能满足要求了 1.1.if标签 我们根据实体类的不 ...

  6. MyBatis --- 动态SQL、缓存机制

    有的时候需要根据要查询的参数动态的拼接SQL语句 常用标签: - if:字符判断 - choose[when...otherwise]:分支选择 - trim[where,set]:字符串截取,其中w ...

  7. JAVAEE——Mybatis第二天:输入和输出映射、动态sql、关联查询、Mybatis整合spring、Mybatis逆向工程

    1. 学习计划 1.输入映射和输出映射 a) 输入参数映射 b) 返回值映射 2.动态sql a) If标签 b) Where标签 c) Sql片段 d) Foreach标签 3.关联查询 a) 一对 ...

  8. mybatis原理分析学习记录,mybatis动态sql学习记录

    以下个人学习笔记,仅供参考,欢迎指正. MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转 ...

  9. 值得注意的ibatis动态sql语法格式

    一.Ibatis常用动态sql语法,简单粗暴用一例子 <select id="iBatisSelectList" parameterClass="java.util ...

  10. Mysql - 游标/动态sql/事务

    游标这个在我目前的项目里面用的还不多, 但是其功能还是很强大的. 动态sql以前都没用过, 是跟着富士康(不是张全蛋的富土康哦)过来的同事学的. 还是挺好用的. 我的数据库方面, 跟他学了不少. 在此 ...

随机推荐

  1. MSSQL语句学习(查询表的总记录数)

    如何高效查询表的总记录数(通用方法) SELECT COUNT(1) ROWS FROM product 野路子1:利用系统自带的存储过程SP_SPACEUSED,详细的使用方式推荐谷哥或度娘, EX ...

  2. 20175316盛茂淞 2018-2019-2《Java程序设计》第4周学习总结

    20175316盛茂淞 2018-2019-2<Java程序设计>第4周学习总结 教材学习内容总结 第五章 子类与继承 一.继承 1.继承定义:避免多个类间重复定义共同行为 2.子类与父类 ...

  3. C#中 property 与 attribute的区别

    说的通俗些Attribute是类,不过是一类比较特殊的类,Attribute必须写在一对方括号中,用来处理.NET中多种问题:序列化.程序的安全特征等等,在.NET中的作用非同凡响 Attribute ...

  4. 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B

    牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...

  5. BeanUtil拷贝

    拷贝vo对象 一些查询到的数据很多是不需要的,可以创建vo对象,对需要的对象属性进行拷贝 maven依赖 <dependency> <groupId>org.projectlo ...

  6. IText实现对PDF文档属性的基本设置

    一.Itext简介 iText是著名的开放源码的站点sourceforge一个项目,是用于生成PDF文档的一个java类库.通过iText不仅可以生成PDF或rtf的文档,而且可以将XML.Html文 ...

  7. 上传input中file文件到云端,并返回链接

    有的文件.图片等信息可以上传到云端上,然后使用链接调用,这样会更加的方便和快捷. <form id="form"> <input type="file& ...

  8. Linux下设置快捷键

    以设置终端为例,进入Settings>>Keyboard>>Custom Shortcuts,点左下脚的+号,Name栏填入Treminal,command栏填入gnome-t ...

  9. 《mysql必知必会》学习_第22章_20180809_欢

    第22章:使用视图,视图是虚拟的表,以表形式呈现的是你查询的结果.并不是说在数据库里面真的存在这个表,但是是真的存在这些数据. select cust_name,cust_contact from c ...

  10. Hive记录-Beeline常用操作命令

    Beeline和其他工具有一些不同,执行查询都是正常的SQL输入,但是如果是一些管理的命令, 比如进行连接,中断,退出,执行Beeline命令需要带上"!",不需要终止符.常用命令 ...