主题
这篇文章主要是记录这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是
1 <sql id="baseColumn"> 2 id, a_b as aB, c_d as cD .............5 sql>
就是表全部列名和对应的DTO的字段.列名可以从自动生成的2.XML里CV过来然后添加DTO的字段即可.下次数据库改了直接在这里修改就行了.
第二个SQL是
1 <sql id="basesql"> 2 select t.* from 3 (select 4 <include refid="baseColumn">include> 5 from table_name ) t 6 sql>
这个SQL其实就是select * from XXX.但是下次数据库字段修改的时候这里是不需要写的.只要改之前的baseColumn即可.比较方便
第三个和第四个SQL是
1 <select id="queryBySql" resultType="cn.evun.tms.tm.dto.TmBatchDto" parameterType="java.util.Map"> 2 select t.* from ( 3 <include refid="basesql">include> 4 ) t where 1=1 5 9 10 <if test="order !=null and order!=''"> 11 ORDER BY ${order} 12 if> 13 LIMIT #{offset},#{limit} 14 select> 15 16 <select id="countBySql" resultType="int" parameterType="java.util.Map"> 17 select count(1) from ( 18 <include refid="basesql">include> 19 ) t where 1=1 23 select>
这2个SQL主要是给界面上查询前20条记录那种datagrid用的.其实自动生成的代码有方法可以达到类似的查询.但是我更喜欢自己写.因为那种mybatis generator自动生成的方法需要再service里拼接条件.
可能会产生大量if( .... !=null){拼接XXX条件}
我觉得还是在这里在dao里自己写可能复用性更高.
以上便是我这2个月对mybatis学习的一些思考和如果自己是架构师会怎么用这个框架的一些大胆的想法.