动态SQL3
Oracle的批量操作
Oracle不支持VALUES(),(),()这种方式,所以不能用上一节所讲的方法。
有时候业务会包含很多次数据库操作,为了减少数据库连接,我们会选择一次提交大量sql,
这时我们会用到begin end,使用begin end需要注意的是,每个sql语句都要确保以";"结尾,代表一句sql结束。
- begin
- insert into tb_employee(id,last_name,email,gender,d_id) VALUES
- (employee_seq.nextval,'Maya','mcl@qq.com','0',1);
- insert into tb_employee(id,last_name,email,gender,d_id) VALUES
- (employee_seq.nextval,'Kafka','kafsl@qq.com','0',2);
- end;
还可以利用中间表,进行批量插入,这部分不熟悉,先跳过,有兴趣的朋友可以深入了解一下,
- <insert id="addEmps">
- begin
- <foreach collection="emps" item="emp">
- insert into tb_employee(id,last_name,email,gender,d_id) VALUES
- (tb_employee_seq.nextval,#{emp.lastName},#{emp.email},#{emp.gender},#{emp.department.id});
- </foreach>
- end;
- </insert>
内置参数
不只是方法传入的参数可以被用来判断、取值,我们还可以使用两个默认的内置参数:_parameter,_databaseId
_parameter:代表整个参数
单个参数:_ parameter就是这个参数
多个参数:参数会被封装成一个map; _parameter就是代表这个map
_databaseId:如果配置了<databaseIdProvider>标签,那么_databaseId就会有值
_databaseId就代表当前数据库的别名
- <select id="getEmpsTestInnerParameter" resultType="com.figsprite.bean.Employee">
- <if test="_databaseId='mysql'">
- select * from tb_employee
- </if>
- <if test="_databaseId='oracle'">
- select * from tb_employee
- </if>
- </select>
- <select id="getEmpsTestInnerParameter" resultType="com.figsprite.bean.Employee">
- select * from tb_employee
- <if test="_parameter!=null">
- where last_name = #{_parameter.lastName}
- </if>
- </select>
<bind>标签
这个标签可以将OGNL表达式的值绑定到一个变量中,方便后来引用这个变量的值
举个例子,我们之前模糊查询的时候出入Employee对象时,要设定它的lastName为"%青%",也就是说这个%,是要认为拼接的,可是有些人,希望只写一个"青",让%由框架帮我们提供,那该怎么办?
- <select id="getEmpsTestInnerParameter" resultType="com.figsprite.bean.Employee">
- select * from tb_employee
- <if test="_parameter!=null">
- where last_name like `%#{ lastName}%`
- </if>
- </select>
这么写行不行?肯定不行,like后面是要作为整体传入数据库查询的,这时候${}就派上用场了,
- <select id="getEmpsTestInnerParameter" resultType="com.figsprite.bean.Employee">
- select * from tb_employee
- <if test="_parameter!=null">
- where last_name like '%${ lastName}%'
- </if>
- </select>
由于${}不会进行预编译,所以它会将拼装完成的SQL语句传入数据库,这样就不会出问题了,当然这样不安全,所以我们希望还是使用#{},这样就不得不用<bind>标签了
- <select id="getEmpsTestInnerParameter" resultType="com.figsprite.bean.Employee">
- <bind name="_lastName" value="'%'+ lastName+'%'"/>
- select * from tb_employee
- <if test="_parameter!=null">
- where last_name like #{_lastName}
- </if>
- </select>
<sql>标签
用于抽取重用的sql语句,比如我们上面的例子中,下面的语句使用了多次,这时就可以考虑使用<sql>标签。
last_name,email,gender,d_id
- <sql id="column">
- last_name,email,gender,d_id
- </sql>
接着将原先是这句话的sql语句,用<include>标签替换
- <insert id="addEmps">
- <foreach collection="emps" item="emp" separator=";">
- INSERT INTO tb_employee(<include refid="column"></include>) VALUES
- (#{emp.lastName},#{emp.email},#{emp.gender},#{emp.department.id})
- </foreach>
- </insert>
- @Test
- public void TestSaveBach() throws IOException {
- SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
- SqlSession openSession = sqlSessionFactory.openSession(true);
- Department department = new Department(2);
- Employee e1 = new Employee("Wendy","0","adcxs@qq.com",department);
- Employee e2 = new Employee("Diyago","1","aaasaadccjdjj@qq.con",department);
- List<Employee> employeeList = new ArrayList<>();
- employeeList.add(e1);
- employeeList.add(e2);
- try{
- EmployeeMapperDynamic mapper = openSession.getMapper(EmployeeMapperDynamic.class);
- mapper.addEmps(employeeList);
- }finally {
- openSession.close();
- }
- }
我们还可以通过<property>标签,自定义一些属性
- <insert id="addEmps">
- <foreach collection="emps" item="emp" separator=";">
- INSERT INTO tb_employee(
- <include refid="column">
- <property name="testColumn" value="test"/>
- </include>
- ) VALUES
- (#{emp.lastName},#{emp.email},#{emp.gender},#{emp.department.id})
- </foreach>
- </insert>
注意这里是用${}取值的
- <sql id="column">
- last_name,email,gender,d_id,${testColumn}
- </sql>
DEBUG [main] - ==> Preparing: INSERT INTO tb_employee( last_name,email,gender,d_id,test ) VALUES (?,?,?,?) ; INSERT INTO tb_employee( last_name,email,gender,d_id,test ) VALUES (?,?,?,?)
动态SQL3的更多相关文章
- 存储过程中执行动态Sql语句
MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的好处就 ...
- 怎样SQL存储过程中执行动态SQL语句
MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的好处就 ...
- SqlServer:SqlServer(存储过程动态表查询(取消返回值),事务处理,批量还原sqlserver备份,强制删除被占用的数据库)
1.存储过程动态表查询 USE [NETWORKING_AUDIT] GO /****** Object: StoredProcedure [dbo].[impConfigInfo] Script D ...
- iOS可视化动态绘制连通图
上篇博客<iOS可视化动态绘制八种排序过程>可视化了一下一些排序的过程,本篇博客就来聊聊图的东西.在之前的博客中详细的讲过图的相关内容,比如<图的物理存储结构与深搜.广搜>.当 ...
- Dapper逆天入门~强类型,动态类型,多映射,多返回值,增删改查+存储过程+事物案例演示
Dapper的牛逼就不扯蛋了,答应群友做个入门Demo的,现有园友需要,那么公开分享一下: 完整Demo:http://pan.baidu.com/s/1i3TcEzj 注 意 事 项:http:// ...
- Ubuntu 16.10 安装byzanz截取动态效果图工具
1.了解byzanz截取动态效果图工具 byzanz能制作文件小,清晰的GIF动态效果图,不足就是,目前只能通过输入命令方式来录制. byzanz主要的参数选项有: -d, --duration=SE ...
- .Net Core MVC 网站开发(Ninesky) 2.3、项目架构调整(续)-使用配置文件动态注入
上次实现了依赖注入,但是web项目必须要引用业务逻辑层和数据存储层的实现,项目解耦并不完全:另一方面,要同时注入业务逻辑层和数据访问层,注入的服务直接写在Startup中显得非常臃肿.理想的方式是,w ...
- 【开源】.Net 动态脚本引擎NScript
开源地址: https://git.oschina.net/chejiangyi/NScript 开源QQ群: .net 开源基础服务 238543768 .Net 动态脚本引擎 NScript ...
- Redis的简单动态字符串实现
Redis 没有直接使用 C 语言传统的字符串表示(以空字符结尾的字符数组,以下简称 C 字符串), 而是自己构建了一种名为简单动态字符串(simple dynamic string,sds)的抽象类 ...
随机推荐
- 寒假训练——搜索——C - Robot
The Robot Moving Institute is using a robot in their local store to transport different items. Of co ...
- 引用变量 php面试总结1
(1)PHP引用变量 概念:不同的变量名,访问同一个变量内容,使用& 知识点: 使用php函数 (a)memory_get_usage() 查看内存使用情况 eg // 定义一个变量 $a = ...
- P1577 切绳子(二分)
思路:先来分析一下数据范围,是1e4个数据,但是,是double类型,结果不超过0.01那么在绳子最大的情况下,单纯的找正确答案暴力的话就是1e7的时间复杂度,再乘上1e4的数据,这样肯定不行.那么很 ...
- 多线程爬虫爬取详情页HTML
注意:如果想爬取详情页的信息请按须添加方法 import requests import os import re import threading from lxml import etree #爬 ...
- OGC标准服务 WMS WCS WFS WPS
网络覆盖服务 (WCS) 网络要素服务 (WFS) 网络地图服务 (WMS) 网络地图切片服务 (WMTS) 网络处理服务 (WPS) 1.Web 地图服务(WMS)能够根据用户的请求返回相应的地图( ...
- VMware 中安装虚拟机和宿主机通信
网络上对于三种连接模式说的很多了,这里就不在具体的说明了.此处采用的NAT模式连接虚拟机,让虚拟机和宿主机互相通讯,并且让虚拟机能访问互联网. 1.首先设置虚拟机的网络,如下图.通过如下操作进入虚拟机 ...
- 对Android系统权限的认识
Android系统是运行在Linux内核上的,Android与Linux分别有自己的一套严格的安全及权限机制 Android系统权限相关的内容 (一)linux文件系统上的权限 -rwxr-x--x ...
- ML.NET 示例:多类分类之鸢尾花分类
写在前面 准备近期将微软的machinelearning-samples翻译成中文,水平有限,如有错漏,请大家多多指正. 如果有朋友对此感兴趣,可以加入我:https://github.com/fei ...
- Item 16: 让const成员函数做到线程安全
本文翻译自modern effective C++,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 博客已经迁移到这里啦 如果我们在数学领域里工作,我们可能会发现用一个类来表示多项式会很方 ...
- 2019 年起如何开始学习 ABP 框架系列文章-开篇有益
2019 年起如何开始学习 ABP 框架系列文章-开篇有益 [[TOC]] 本系列文章推荐阅读地址为:52ABP 开发文档 https://www.52abp.com/Wiki/52abp/lates ...