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. 本次例子 ...
随机推荐
- BZOJ3438:小M的作物 (最大闭合权图->最小割)
小M在MC里开辟了两块巨大的耕地A和B(你可以认为容量是无穷),现在,小P有n中作物的种子,每种作物的种子 有1个(就是可以种一棵作物)(用1...n编号),现在,第i种作物种植在A中种植可以获得ai ...
- Python学习-第三方库操作
2018-05-04 12:03:19 Python安装模块,更新模块 #显示模块 pip list #显示过期模块 pip list --outdated #安装模块 pip install x ...
- mysql update select 用法
之前用SqlServer , update语句对表进行更新:update a set a.xx= (select yy from b) ; 是可以的但是在mysql中,不能直接使用set select ...
- 借助CustomBehaviorsLibrary.dll写出水印效果(转)
在项目中载入这个dll 之后引用 使用方法具体如下图: 在这里需要注意到是项目中对interactivity的引用 : 好文要顶 关注我 收藏该文
- Helm Charts
Use this repository to submit official Charts for Kubernetes Helm. Charts are curated application de ...
- InnoSetup 打包Winform程序
在VS2012之前,我们做安装包一般都是使用VS自带的安装包制作工具来创建安装包的,VS2012.VS2013以后,微软把这个去掉,集成使用了InstallShield进行安装包的制作了,虽然思路差不 ...
- Junit+ant+JaCoCo集成使用
接上文,本文主要介绍Junit+ant+JaCoCo集成使用 1.工具的下载上传 需要的工具有: apache-ant-1.10.5-bin.tarapache-tomcat-8.0.50.tarja ...
- Docker阿里云镜像加速器 for CentOS 7
CentOS 7 CentOS使用配置方式略微复杂,需要先将默认的配置文件复制出来 /lib/systemd/system/docker.service -> /etc/systemd/syst ...
- caffe读取多标签的lmdb数据
问题描述: lmdb文件支持数据+标签的形式,但是却只能写入一个标签,引入多标签的解决方法有很多,这儿详细说一下我的办法:制作多个data数据,分别加入一个标签.我的方法只适用于标签数量较少的情况,标 ...
- Druid.io系列(一):简介
原文链接: https://blog.csdn.net/njpjsoftdev/article/details/52955676 Druid.io(以下简称Druid)是面向海量数据的.用于实时查询与 ...