根据不同的条件需要执行不同的 SQL 命令.称为动态 SQL

MyBatis 中动态 SQL 在 mapper.xml 中添加逻辑判断等

一、if使用

select * from log where 1=1

and accin=#{accin}

and accout=#{accout}

二、where

当编写 where 标签时,如果内容中第一个是 and 去掉第一个and

如果中有内容会生成 where 关键字,如果没有内容不生成 where 关键字

select * from log

and accin=#{accin}

and accout=#{accout}

三、

只有有一个成立,其他都不执行.

如果 accin 和 accout 都不是 null 或不是””生成的 sql 中只有 where accin=?

select * from log

and accin=#{accin}

and accout=#{accout}

四 用在修改 SQL 中 set 从句

作用:去掉最后一个逗号

作用:如果里面有内容生成 set 关键字,没有就不生成

下面代码的前面id=#{id} 目的防止中没有内容,mybatis 不生成 set 关键字,如果修改中没有 set 从句 SQL 语法错误.

update log

id=#{id},

accin=#{accIn},

accout=#{accOut},

where id=#{id}

五、Trim

prefix 在前面添加内容

prefixOverrides 去掉前面内容

suffix 在后面添加内容

suffixOverrieds 去掉后面内容

执行顺序是:去掉内容后添加内容

update log

a=a,

where id=100

六、

作用:给参数重新赋值

场景:模糊查询、在原内容前或后添加内容

#{money}

七、标签

循环参数内容,还具备在内容的前后添加内容,还具备添加分隔符功能.

适用场景:in 查询中.批量新增中(mybatis 中 foreach 效率比较低)

如果希望批量新增,SQL 命令如下

insert into log VALUES (default,1,2,3),(default,2,3,4),(default,3,4,5)

使用openSession()必须指定如下代码,其原理是底层 JDBC 的PreparedStatement.addBatch();

factory.openSession(ExecutorType.BATCH);

collectino=”” 要遍历的集合

item 迭代变量, #{迭代变量名}获取内容9.3.3 open 循环后左侧添加的内容

close 循环后右侧添加的内容

separator 每次循环时,元素之间的分隔符

resultType="log">

select * from log where id in

#{abc}

八、 和

某些 SQL 片段如果希望复用,可以使用定义这个片段

id,accin,accout,money

在或或或中使用引用

select

from log

java when for where_JAVA_EE_MyBatis之动态SQL相关推荐

  1. dao层动态sql利器!数据持久化jpa插件spring-data-jpa-extra?Fenix!

    把hibernate.mybatis都整合到一个项目中,有没有觉得臃肿繁琐?!        我们知道,dao层,会用数据持久化框架,如hibernate.mybatis等,他们都实现了jpa规范.几 ...

  2. MyBatis list Contains MyBatis 动态SQL 判断List Contains

    MyBatis list Contains MyBatis 动态SQL 判断List Contains 一.情景描述 在使用MyBatis 动态SQL查询时,有时候需要判断集合中是否有某个元素,若存在 ...

  3. 【Java调试】通过SqlSessionFactory类对象获取mapper文件内的动态SQL在执行时的完整SQL及参数(2种使用方法+测试Demo及结果)

    1. 问题 最近开发新功能,调试 mapper.xml 里的SQL,遇到了极其痛苦的事情: 没有 p6spy SQL无法输出到工作台. mapper 接口没有实现 MyBatis 的 BaseMapp ...

  4. java mysql 动态sql_Java下拼接运行动态SQL语句

    Java拼接动态SQL的一般做法有 1.使用动态语句 非常多数据库都提供了处理动态SQL的语法,如Oracle的EXECUTE IMMEDIATE语句.MSSQL的EXEC和SP_EXECUTESQL ...

  5. 【Java从0到架构师】MyBatis - 增删改、动态 SQL

    MyBatis - 增删改.动态 SQL 动态 SQL if 标签 where 标签 sql 标签 foreach 标签 添加 主键设置 批量添加 - 利用 foreach 标签 更新 删除 批量删除 ...

  6. java回顾:MyBatis参数、sql片段、动态sql、高级查询

    目录 一.MyBatis参数 SqlSessiong工具类 1.映射文件配置-入参 1.1 parameterType入参 1.2 单个入参,变量名任意定义: 1.3 多个入参,解决方案: 1.4 p ...

  7. JAVA日记之mybatis-2代理开发/动态sql/sql抽取/核心配置标签 ----喝最烈的酒.

    1.Mybatis的Dao层实现 1.1 传统开发方式 1.1.1编写UserDao接口 public interface UserDao {List<User> findAll() th ...

  8. java 生成mysql dto_如何根据动态SQL代码自动生成DTO

    当前的状况 一般做数据库相关开发, 除非学习, 否则很少有人愿意直接使用JDBC.本来Java代码就比较啰嗦了,而直接用JDBC写代码之啰嗦简直有些令人发狂!所以在实际开发过程中,我们通常都会使用一些 ...

  9. java sql超过32k_ibatis调用oracle的动态sql,sql大小不能超过32K

    1环境:oracle10g,spring2.5,ibatis2.3. 2由于项目里面要调用oracle的存储过程,原本采用如下方法调用: {call ?=Tlgadmin.check(?,?)} 但实 ...

最新文章

  1. php 遍历所有的文件
  2. 大脑天天超负荷,三分天赋,七分练,世间惊现普通脑修炼秘籍
  3. 一季度手机出货量少了2800万部,有人要给「指条明路」
  4. Spring入门详细教程(一)
  5. php fpm 日志记录,如何解决nginx下php-fpm不记录php报错日志的问题
  6. PHP页面间参数传递的四种方式
  7. UVa 297 四分树
  8. 华威、剑桥与三星联合提出基于时间核一致性的盲视频超分辨率
  9. 在 Linux 命令行发送邮件的 5 种方法
  10. 头目说“我不参与研发和测试的工作”,包含哪几个意思
  11. 前端培训Ajax-onreadystatechange 事件
  12. Qt编写安防视频监控系统60-子模块4云台控制
  13. To install it, you can run: npm install --save element-uib/theme-chalk/index.css
  14. php empty是什么意思,php empty 和空字符串区别
  15. python语句中print(type(1j))_Python语句 print(type(1J))的输出结果是:________
  16. 唯品会基于Kubernetes(k8s)网络方案演进
  17. 原创 METTLER TOLEDO托利多Bplus 条码格式设置教程(scale manager)
  18. 编剧小记 — Contour
  19. autocad2014点击保存闪退_AutoCAD2014闪退的具体原因和解决方法介绍
  20. Java要学到什么程度?

热门文章

  1. 王道机试指南读后总结-1
  2. 最新版 | 李沐《动手学深度学习》中文版pdf重磅开源!
  3. 首篇NLP图神经网络综述!127页文档让你全面了解这个领域
  4. js获取的值传到java_使用GraalVM从javascript将变量参数传递给java函数
  5. 自建服务器同步软件,自建Syncthing中继服务器(私密传输或造福大众)
  6. Keras-Sequential模型(1)
  7. Leetcode每日一题:38.Count and Say(外观数列)
  8. 蓝桥杯 基础练习 阶乘计算
  9. Spring包的依赖关系以及提供下载
  10. python接口自动化(三十四)-封装与调用--函数和参数化(详解)