MyBatis实操进阶版(一)
MyBatis实操进阶版(一)
目前而言,持久层框架中,在业务实现灵活性上,无可出MyBatis之右者.具体原因,后续将逐步展开
ResultMap元素的设置
配置文件中,ResultMap元素的作用临时存储sql执行结果集与Java对象之间的映射,用以实现数据的持久性.基于此,sql返回结果集更加多样/不必局限于表关系,同时接收对象更加灵活多变,可以自由根据数据需求,设置接收字段,搭配association和collection标签,可以灵活设置数据子集的配置,而且进一步降低了业务层与数据库间的交互次数,尤其是在处理复杂业务逻辑sql设置的时候,完成这一套配置后,唯一的感觉--爽.
示例 : 业务逻辑省略,直接上代码
Java对象设置: -- 包含集合
public class CameraTrackInfo {
private Integer personId;
private String faviconUrl;
private String name;
private Long startTime;
private Long endTime;
private String cameraId;
private List<CameraTrack> cameraTracks;
... ...
}
xml配置(resultMap & sql)
resultMap设置,其中包含子元素集获取多参传输的问题,博客后半部分详解
<resultMap id="rightListMap" type="com.rosetta.face.entity.CameraTrackInfo">
<result column="person_id" property="personId" jdbcType="INTEGER" />
<result column="favicon_url" property="faviconUrl" jdbcType="VARCHAR" />
<result column="name" property="name" jdbcType="VARCHAR" />
<result column="start_time" property="startTime" jdbcType="BIGINT" />
<result column="end_time" property="endTime" jdbcType="BIGINT" />
<result column="camera_id" property="cameraId" jdbcType="VARCHAR" />
<collection property="cameraTracks" column="{startTime=start_time,endTime=end_time,cameraId=camera_id,personId=person_id}" select="selectTracksById" />
</resultMap>
子结果集获取
<select id="selectTracksById" parameterType="java.util.Map" resultMap="BaseResultMap">
SELECT c.id,c.camera_id,c.person_id,c.now_timestamp,c.url
FROM camera_track c
<where>
<if test="personId != null">
AND c.person_id = #{personId}
</if>
<if test="startTime != null and endTime != null">
AND c.now_timestamp >= #{startTime} AND c.now_timestamp <= #{endTime}
</if>
<if test="cameraId != null">
AND c.camera_id = #{cameraId}
</if>
</where>
ORDER BY c.now_timestamp
</select>
结果集获取,此处包含参数传递的设置,下文详解
<select id="queryBossCameraTracks" resultMap="rightListMap" parameterType="java.util.Map">
SELECT DISTINCT c.person_id,p.favicon_url,p.name,#{params.startTime} AS start_time,#{params.endTime} AS end_time,#{params.area} AS camera_id
FROM camera_track c
LEFT OUTER JOIN person p ON c.person_id = p.person_id
<where>
<if test="params.personId != null">
AND c.person_id = #{params.personId}
</if>
<if test="params.personName != null">
AND p.name=#{params.personName}
</if>
<if test="params.startTime != null and params.endTime != null">
AND c.now_timestamp >= #{params.startTime} AND c.now_timestamp <= #{params.endTime}
</if>
<if test="params.area != null">
AND c.camera_id = #{params.area}
</if>
</where>
ORDER BY c.now_timestamp
</select>
Mapper接口实现,同上,下文详解
List<CameraTrackInfo> queryBossCameraTracks(@Param("params")Map<String,Object> map);
概述,上述代码用以实现结果集中某字段为条件进一步获取子结果集,组合获取最终结果集的过程.
MyBatis参数设置为Map
实际开发中,不可能因为请求参数多个就随意新增实体类,Map的使用尤其关键,这里不同于表现层Map参数获取运行期报错,MyBatis支持Map传参.
1) 使用 @Param注解,并设置唯一性key,故Map可以是多个,用key加以区分即可
2) xml中,key.column的形式传递参数
ResultMap子结果集获取多参传递
子结果集的获取单个和多个出现的频率都很高,同时,有些参数并不在原有的结果集中就有,需要更上一级来传递,这时候就需要在select的返回结果中做文章,这就是前文代码的逻辑.
1) select 'param' as column from dual . 自定义设置返回结果,设置结果中字段column的值为param
2)<collection column="{aa=bb,cc=dd....}">,aa/cc为自定义key,并根据结果集字段<result>中的 column属性设置value(bb/dd).
3)子结果集查询sql在接收参数时,无需设置key,直接引用字段即可.
MyBatis实操进阶版(一)的更多相关文章
- ElasticSearch7.2简单命令实操(postman版)
使用postman访问操作ElasticSearch数据库,数据格式均为json 目录 使用postman访问操作ElasticSearch数据库,数据格式均为json 一.集群设置 1.查看集群设置 ...
- Docker安装MySql完整教程、实操
docker:官网 docker:镜像官网: 镜像官网可以所有应用,选择安装环境:会给出安装命令,例如:docker pull redis 默认拉取最新的版本(指定版本:docker p ...
- QVM 实操记 - 18.12.28
视频回放地址:https://i.iamlj.com/mp4/QVM-IMC-12.27-1080P.mp4 目录 目录 常规开发部署流程 准备工作 开发准备 网站部署 操作步骤 重装系统 LANP环 ...
- 如约而至,Java 10 正式发布! Spring+SpringMVC+MyBatis+easyUI整合进阶篇(十四)Redis缓存正确的使用姿势 努力的孩子运气不会太差,跌宕的人生定当更加精彩 优先队列详解(转载)
如约而至,Java 10 正式发布! 3 月 20 日,Oracle 宣布 Java 10 正式发布. 官方已提供下载:http://www.oracle.com/technetwork/java ...
- 百度NLP预训练模型ERNIE2.0最强实操课程来袭!【附教程】
2019年3月,百度正式发布NLP模型ERNIE,其在中文任务中全面超越BERT一度引发业界广泛关注和探讨.经过短短几个月时间,百度ERNIE再升级,发布持续学习的语义理解框架ERNIE 2.0,及基 ...
- 从零实操基于WSL2 Docker部署Asp.Net Core项目
前言 平日在公司里都是基于阿里Teambition中的飞流进行Docker部署Api项目或服务,已经习惯了那一套成熟的操作流程,开发和部署确实快捷方便,但是还没在自己的电脑上进行操作过,特别是Wind ...
- Iptables 实操
目录 Iptables之实操 简介 名称概念: 四表中常用的表 Nat表 Filter表 iptables表和链的工作流程图 iptables过滤图 Iptables安装 Iptables 命令说明 ...
- 生产环境搭建高可用Harbor(包括恢复演练实操)
生产环境搭建高可用Harbor(包括恢复演练实操) 前言 因资源成本问题,本Harbor高可用架构为最小开销方案,如果资源充足,可以将PG.Redis全部使用使用云厂商集群模式. 同时为了配置简单,并 ...
- jmeter & 性能测试:从0到实战(实操易用、面试造火箭、升职加薪必备)
[性能基础] 性能测试概念.术语:https://www.cnblogs.com/uncleyong/p/10706519.html 性能测试流程(新):https://www.cnblogs.com ...
随机推荐
- HTTP协议详细分析
1.HTTP概述 1.1.什么是HTTP? 它是Hyper Text Transfer Protocol的缩写.超文本传输协议. 它是客户浏览器和web服务器之间的一种一问一答的规则.问答机制/握手机 ...
- 九、xadmin菜单分组管理
有的时候,我们的菜单很多很杂,想要把菜单进行分组以方便管理,如下 前一篇博文已经详细讲解了如何菜单自定义排序,自定义分组和排序其实写法类似: 要实现上面这个功能,分为以下几步: 1. 我们需要定义一个 ...
- Python迭代器与格式化
三元运算 对if-else判断的简写 >>> age = 18 >>> res = "You are so young!" if age < ...
- Java向下转型的意义
一开始学习 Java 时不重视向下转型.一直搞不清楚向下转型的意义和用途,不清楚其实就是不会,那开发的过程肯定也想不到用向下转型. 其实向上转型和向下转型都是很重要的,可能我们平时见向上转型多一点,向 ...
- 软工+C(8): 提问与回复
// 上一篇:野生程序员 // 下一篇:助教指南 在线上博客教学里引入了第三方助教,助教在每次作业期间尽力完成"消灭零点评"的目标.然而紧接而来的问题是:学生对博客作业点评的回复率 ...
- MySQL 5.7 Reference Manual :: 4.5.4 mysqldump & mysql — Database Backup & Restore Program
MySQL :: MySQL 5.7 Reference Manual :: 4.5.4 mysqldump — A Database Backup Programhttps://dev.mysql. ...
- [转帖]IP地址、子网掩码、网络号、主机号、网络地址、主机地址以及ip段/数字-如192.168.0.1/24是什么意思?
IP地址.子网掩码.网络号.主机号.网络地址.主机地址以及ip段/数字-如192.168.0.1/24是什么意思? 2016年03月26日 23:38:50 JeanCheng 阅读数:105674 ...
- fatal: HttpRequestException encountered解决方法
最近在windows下git push提交就会弹出如下错误: 网上查了一下发现是Github 禁用了TLS v1.0 and v1.1,必须更新Windows的git凭证管理器,才行. https:/ ...
- 你不知道的JavaScript——第二章:this全面解析
1调用位置 调用栈:为了到达当前执行位置所调用的所有函数. function baz(){ //当前调用栈:baz //因此,当前调用位置是全局作用域 console.log('baz'); bar( ...
- Spring 的java 配置方式
Java配置是Spring4.x推荐的配置方式,可以完全替代xml配置. 1.1@Configuration 和 @Bean Spring的Java配置方式是通过 @Configuration 和 @ ...