mybatis 用法分享
主题
这篇文章主要是记录这2个月我对mybatis的学习以后的一些感触和一些如果我是架构师会怎么在项目里使用mybatis的一些大胆的想法.
感想
1.首先根据之前的学习我已经知道了mybatis generator这个插件..可以自动生成代码,帮我们节约不少力气..所以项目可以使用.
我们在数据库里建立表以后我们可以使用mybatis generator自动生成mapper dto xml文件.
这些包括了绝大部分单表的CRUD操作.可以节约非常多的时间.
2.前面自动生成的mapper对应的XML我想把他名字改成XXX2.xml
然后我再手写一个XXX.xml
这2个mapper XML里的namespace都是一样的,都对应那个mapper类.(我觉得这是mybatis非常好的一个特性,1个mapper类可以对应多个XML,这样我可以分类把不同SQL些到不同XML文件里便于维护)
为什么这样分2个XML文件呢?因为如果下次数据库修改过了.我就重新生成XML覆盖XXX2.xml,而XXX.xml是由我们自己维护,写一些除了自动生成的CRUD以外的SQL.
这样相当于是把自动生成的代码和手动生成的代码分离开了.下次改动表的时候维护起来会简单很多.
3.在XXX.xml(自己维护的那个XML文件)里我一般会写几个SQL
第一个SQL是
<sql id="baseColumn">
id, a_b as aB, c_d as cD ............. </sql>
就是表全部列名和对应的DTO的字段.列名可以从自动生成的2.XML里CV过来然后添加DTO的字段即可.下次数据库改了直接在这里修改就行了.
第二个SQL是
<sql id="basesql">
select t.* from
(select
<include refid="baseColumn"></include>
from table_name ) t
</sql>
这个SQL其实就是select * from XXX.但是下次数据库字段修改的时候这里是不需要写的.只要改之前的baseColumn即可.比较方便
第三个和第四个SQL是
<select id="queryBySql" resultType="cn.evun.tms.tm.dto.TmBatchDto" parameterType="java.util.Map">
select t.* from (
<include refid="basesql"></include>
) t where 1=1 <if test="order !=null and order!=''">
ORDER BY ${order}
</if>
LIMIT #{offset},#{limit}
</select> <select id="countBySql" resultType="int" parameterType="java.util.Map">
select count(1) from (
<include refid="basesql"></include>
) t where 1=1
</select>
这2个SQL主要是给界面上查询前20条记录那种datagrid用的.其实自动生成的代码有方法可以达到类似的查询.但是我更喜欢自己写.因为那种mybatis generator自动生成的方法需要再service里拼接条件.
可能会产生大量if( .... !=null){拼接XXX条件}
我觉得还是在这里在dao里自己写可能复用性更高.
以上便是我这2个月对mybatis学习的一些思考和如果自己是架构师会怎么用这个框架的一些大胆的想法.
mybatis 用法分享的更多相关文章
- 用c#开发微信 (10) JS-SDK 基本用法- 分享接口“发送到朋友”
微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包.通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统的能力,同时可以直接使用微信分享. ...
- 用c#开发微信(10) JSSDK 基本用法 分享接口“发送到朋友”
微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包.通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统的能力,同时可以直接使用微信分享. ...
- Mybatis用法小结
select 1.基本用法 <select id="selectTableOne" resultType="com.test.entity.tableOne&quo ...
- mybatis用法
转载:https://www.cnblogs.com/xdp-gacl/p/4261895.html 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架 ...
- requirejs模块化框架用法分享
我采用的是一个非常流行的库require.js. 一.为什么要用require.js? 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码越来越多,一 ...
- Bash Shell中Shift用法分享
这篇文章主要介绍了Bash Shell中Shift的使用方法,需要的朋友可以参考下 shift可以用来向左移动位置参数.Shell的名字 $0第一个参数 $1第二个参数 $2第n个参数 $n所有参数 ...
- 用c#开发微信 (12) 微统计 - 阅读分享统计系统 2 业务逻辑实现
微信平台自带的统计功能太简单,有时我们需要统计有哪些微信个人用户阅读.分享了微信公众号的手机网页,以及微信个人用户访问手机网页的来源:朋友圈分享访问.好友分享消息访问等.本系统实现了手机网页阅读.分享 ...
- 初识 tk.mybatis.mapper
在博客园发表Mybatis Dynamic Query后,一位园友问我知不知道通用mapper,仔细去找了一下,还真的有啊,比较好的就是abel533写的tk.mybatis.mapper. 本次例子 ...
- 初识 tk.mybatis.mapper 通用mapper
在博客园发表Mybatis Dynamic Query后,一位园友问我知不知道通用mapper,仔细去找了一下,还真的有啊,比较好的就是abel533写的tk.mybatis.mapper. 本次例子 ...
随机推荐
- linux自学(一)之vmware虚拟机安装
之前有研究过linux,后来一段时间没有操作了,现在有点陌生,而且当初也没有记录学习内容.现在想从新开始包括虚拟机安装到部署Javaweb项目,把这之间所需要的全都记录下来,以便后边学习参考使用. 虚 ...
- BZOJ4561 JLoi2016 圆的异或并 【扫描线】【set】*
BZOJ4561 JLoi2016 圆的异或并 Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一片区 ...
- 通过解读 WPF 触摸源码,分析 WPF 插拔设备触摸失效的问题(问题篇)
在 .NET Framework 4.7 以前,WPF 程序的触摸处理是基于操作系统组件但又自成一套的,这其实也为其各种各样的触摸失效问题埋下了伏笔.再加上它出现得比较早,触摸失效问题也变得更加难以解 ...
- 接口测试框架——第二篇-python读取excel文件内容
今天完善excel_module.py文件,上代码: # coding: utf-8 import xlrd class ReadExcel(): def __init__(self, file_na ...
- UVA11538 Chess Queen
题意 给一个\(n \times m\)的棋盘,输出有多少种方法放置两个互相攻击的皇后. \(n,m \leq 10^6\) 分析 参照刘汝佳的题解. 横.竖.斜三种情况互不相干,加法原理统计. 横竖 ...
- 安装WampServer关闭mysql服务后打不开了
WampServer自带了mysql精简班的数据库了 WampServer自带 的mysql和你独立安装的mysql端口号冲突了 mysql默认的端口号是3306 建议你修改WampServer的数据 ...
- 操作系统CPU上下文切换
关于CPU,有3个重要的概念:上下文切换(context switchs),运行队列(Run queue)和使用率(utilization). 上下文切换: 目前流行的CPU在同一时间内只能运行一个线 ...
- MySQL出现1030-Got error 28 from storage engine错误
Navicat for MySQL出现1030-Got error 28 from storage engine错误 刚刚还能用这会儿就用不了了,估计是磁盘空间不足引起的! 在根目录/下执行命令:d ...
- maven打包报错:在类路径或引导类路径中找不到程序包 java.lang
刚下了个新项目,跑了下maven报错了: E:\workspace\portalframe>mvn clean install [INFO] Scanning for projects... [ ...
- volatile浅析
volatile的意思是不稳定的.易变的,但在多线程中却跟字面意思一毛钱关系没有.作为一个变量修饰符,它主要有两个作用:一个是告诉大家,该变量是一个在多个线程之间均可见的变量:另一个是告诉java虚拟 ...