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. 本次例子 ...
随机推荐
- python笔记-20 django进阶 (model与form、modelform对比,三种ajax方式的对比,随机验证码,kindeditor)
一.model深入 1.model的功能 1.1 创建数据库表 1.2 操作数据库表 1.3 数据库的增删改查操作 2.创建数据库表的单表操作 2.1 定义表对象 class xxx(models.M ...
- python pandas 对各种文件的读写 IO tools
The pandas I/O API is a set of top level reader functions accessed like pd.read_csv() that generally ...
- vue-router教程二(要素篇之新手入门)
注意,我们将在指南中使用es 2015代码样本.此外,所有示例都将使用VUE的完整版本来使在线模板编译成为可能.请参阅这里的更多细节. 用vue路由器创建单页应用程序是非常简单的.使用vue.js,我 ...
- Vim使用YouCompleteMe达到类似IDE的代码提示、补全,以及其他实用设置
接触Linux有两年了,vim还是只会简单的操作.最近实在受不了sublime的代码提示,决定花点时间来配置下vim.本文讲自己认为方便的vim配置,称不上完美,只讲究简单实用. 使用 ctags 主 ...
- hibernate规避SQL注入实例
项目被检测出SQL注入,注入url如:http://127.0.0.1:8080/Test/wlf/getServiceInfo.html?province=%25E6%25B5%2599%25E6% ...
- 安装sphinx报错(undefined reference to `libiconv_open' 、undefined reference to `libiconv'、undefined reference to `libiconv_close'、make[1]: *** No rule to make target `all'. Stop. 、make: *** [all-recursive
(为知笔记copy过来格式有变,希望对遇到此问题的童鞋有帮助) 具体错误: Thank you for choosing Sphinx! [root@vm-vagrant csft-4.1]# mak ...
- Eclipse中创建新的Spring Boot项目
本文转载自:http://blog.csdn.net/clementad/article/details/51334064 简单几步,在Eclipse中创建一个新的spring Boot项目: 1.E ...
- Firewalld防火墙与ICMP攻击
原文地址:http://www.excelib.com/article/293/show 提到ICMP大家应该都很熟悉,可能有人会说:不就是ping吗?但是说到ICMP攻击以及相关防御措施可能就有的人 ...
- bzoj2184: 任意图的匹配
Description 每天都要考,每天都要讲,大家注意力都集中不起来了,每天听解题报告时都有人交头接耳(也包括我,呵呵).这样做大大的影响的学习效率(可能吧).于是,有些好奇心重的同学就开始研究,怎 ...
- 操作系统-百科: UNIX
ylbtech-操作系统-百科: UNIX UNIX操作系统(尤尼斯),是一个强大的多用户.多任务操作系统,支持多种处理器架构,按照操作系统的分类,属于分时操作系统,最早由KenThompson.De ...