java when for where_JAVA_EE_MyBatis之动态SQL
根据不同的条件需要执行不同的 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相关推荐
- dao层动态sql利器!数据持久化jpa插件spring-data-jpa-extra?Fenix!
把hibernate.mybatis都整合到一个项目中,有没有觉得臃肿繁琐?! 我们知道,dao层,会用数据持久化框架,如hibernate.mybatis等,他们都实现了jpa规范.几 ...
- MyBatis list Contains MyBatis 动态SQL 判断List Contains
MyBatis list Contains MyBatis 动态SQL 判断List Contains 一.情景描述 在使用MyBatis 动态SQL查询时,有时候需要判断集合中是否有某个元素,若存在 ...
- 【Java调试】通过SqlSessionFactory类对象获取mapper文件内的动态SQL在执行时的完整SQL及参数(2种使用方法+测试Demo及结果)
1. 问题 最近开发新功能,调试 mapper.xml 里的SQL,遇到了极其痛苦的事情: 没有 p6spy SQL无法输出到工作台. mapper 接口没有实现 MyBatis 的 BaseMapp ...
- java mysql 动态sql_Java下拼接运行动态SQL语句
Java拼接动态SQL的一般做法有 1.使用动态语句 非常多数据库都提供了处理动态SQL的语法,如Oracle的EXECUTE IMMEDIATE语句.MSSQL的EXEC和SP_EXECUTESQL ...
- 【Java从0到架构师】MyBatis - 增删改、动态 SQL
MyBatis - 增删改.动态 SQL 动态 SQL if 标签 where 标签 sql 标签 foreach 标签 添加 主键设置 批量添加 - 利用 foreach 标签 更新 删除 批量删除 ...
- java回顾:MyBatis参数、sql片段、动态sql、高级查询
目录 一.MyBatis参数 SqlSessiong工具类 1.映射文件配置-入参 1.1 parameterType入参 1.2 单个入参,变量名任意定义: 1.3 多个入参,解决方案: 1.4 p ...
- JAVA日记之mybatis-2代理开发/动态sql/sql抽取/核心配置标签 ----喝最烈的酒.
1.Mybatis的Dao层实现 1.1 传统开发方式 1.1.1编写UserDao接口 public interface UserDao {List<User> findAll() th ...
- java 生成mysql dto_如何根据动态SQL代码自动生成DTO
当前的状况 一般做数据库相关开发, 除非学习, 否则很少有人愿意直接使用JDBC.本来Java代码就比较啰嗦了,而直接用JDBC写代码之啰嗦简直有些令人发狂!所以在实际开发过程中,我们通常都会使用一些 ...
- java sql超过32k_ibatis调用oracle的动态sql,sql大小不能超过32K
1环境:oracle10g,spring2.5,ibatis2.3. 2由于项目里面要调用oracle的存储过程,原本采用如下方法调用: {call ?=Tlgadmin.check(?,?)} 但实 ...
最新文章
- php 遍历所有的文件
- 大脑天天超负荷,三分天赋,七分练,世间惊现普通脑修炼秘籍
- 一季度手机出货量少了2800万部,有人要给「指条明路」
- Spring入门详细教程(一)
- php fpm 日志记录,如何解决nginx下php-fpm不记录php报错日志的问题
- PHP页面间参数传递的四种方式
- UVa 297 四分树
- 华威、剑桥与三星联合提出基于时间核一致性的盲视频超分辨率
- 在 Linux 命令行发送邮件的 5 种方法
- 头目说“我不参与研发和测试的工作”,包含哪几个意思
- 前端培训Ajax-onreadystatechange 事件
- Qt编写安防视频监控系统60-子模块4云台控制
- To install it, you can run: npm install --save element-uib/theme-chalk/index.css
- php empty是什么意思,php empty 和空字符串区别
- python语句中print(type(1j))_Python语句 print(type(1J))的输出结果是:________
- 唯品会基于Kubernetes(k8s)网络方案演进
- 原创 METTLER TOLEDO托利多Bplus 条码格式设置教程(scale manager)
- 编剧小记 — Contour
- autocad2014点击保存闪退_AutoCAD2014闪退的具体原因和解决方法介绍
- Java要学到什么程度?
热门文章
- 王道机试指南读后总结-1
- 最新版 | 李沐《动手学深度学习》中文版pdf重磅开源!
- 首篇NLP图神经网络综述!127页文档让你全面了解这个领域
- js获取的值传到java_使用GraalVM从javascript将变量参数传递给java函数
- 自建服务器同步软件,自建Syncthing中继服务器(私密传输或造福大众)
- Keras-Sequential模型(1)
- Leetcode每日一题:38.Count and Say(外观数列)
- 蓝桥杯 基础练习 阶乘计算
- Spring包的依赖关系以及提供下载
- python接口自动化(三十四)-封装与调用--函数和参数化(详解)