1.代碼生成 2.條件構(gòu)造器
對(duì)我而言,主要的目的是使用它強(qiáng)大的條件構(gòu)建器.
快速使用步驟:
1.添加pom文件依賴(lài)
1
2
3
4
5
6
7
8
9
10
|
<dependency> <groupid>org.apache.velocity</groupid> <artifactid>velocity</artifactid> <version> 1.7 </version> </dependency> <dependency> <groupid>com.baomidou</groupid> <artifactid>mybatis-plus</artifactid> <version> 2.0 . 1 </version> </dependency> |
注意:mybatis-plus會(huì)自動(dòng)維護(hù)mybatis以及mybatis-spring的依賴(lài),所以不需要引入后兩者,避免發(fā)生版本沖突.
2.修改配置文件
將mybatis的sqlsessionfactory替換成mybatis-plus的即可,mybatis-plus只做了一些功能的擴(kuò)展:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<property name= "datasource" ref= "datasource" /> <!-- 自動(dòng)掃描mapping.xml文件 --> <property name= "mapperlocations" value= "classpath:mybatis/*/*.xml" /> <property name= "configlocation" value= "classpath:mybatis/mybatis-config.xml" /> <property name= "typealiasespackage" value= "com.baomidou.springmvc.model.*" /> <property name= "plugins" > <array> <!-- 分頁(yè)插件配置 --> <bean id= "paginationinterceptor" class = "com.baomidou.mybatisplus.plugins.paginationinterceptor" > <property name= "dialecttype" value= "mysql" /> </bean> </array> </property> <!-- 全局配置注入 --> <property name= "globalconfig" ref= "globalconfig" /> </bean> |
在上面的配置中,除了mybatis的常規(guī)配置,多了一個(gè)分頁(yè)插件的配置和全局配置,mybatis-plus提供了很方便的使用分頁(yè)的插件,還有一個(gè)全局配置如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
<bean id= "globalconfig" class = "com.baomidou.mybatisplus.entity.globalconfiguration" > <!-- auto->` 0 `( "數(shù)據(jù)庫(kù)id自增" ) input->` 1 `(用戶(hù)輸入id") id_worker->` 2 `( "全局唯一id" ) uuid->` 3 `( "全局唯一id" ) --> <property name= "idtype" value= "2" /> <!-- mysql->`mysql` oracle->`oracle` db2->`db2` h2->`h2` hsql->`hsql` sqlite->`sqlite` postgre->`postgresql` sqlserver2005->`sqlserver2005` sqlserver->`sqlserver` --> <!-- oracle需要添加該項(xiàng) --> <!-- <property name= "dbtype" value= "oracle" /> --> <!-- 全局表為下劃線命名設(shè)置 true --> <property name= "dbcolumnunderline" value= "true" /> </bean> |
至此,配置工作就算大功告成了,接下來(lái)通過(guò)一個(gè)簡(jiǎn)單的例子來(lái)感受一下它的使用.
1.新建一個(gè)user表:
1
2
3
4
5
6
7
8
9
10
11
|
@tablename ( "user" ) public class user implements serializable { /** 用戶(hù)id */ private long id; /** 用戶(hù)名 */ private string name; /** 用戶(hù)年齡 */ private integer age; @tablefield (exist = false ) private string state; } |
這里有兩個(gè)注解需要注意,第一是@tablename("user"),它是指定與數(shù)據(jù)庫(kù)表的關(guān)聯(lián),這里的注解意味著你的數(shù)據(jù)庫(kù)里應(yīng)該有一個(gè)名為user的表與之對(duì)應(yīng),并且數(shù)據(jù)表的列名應(yīng)該就是user類(lèi)的屬性,對(duì)于user類(lèi)中有而user表中沒(méi)有的屬性需要加第二個(gè)注解@tablefield(exist = false),表示排除user類(lèi)中的屬性.
2.新建dao層接口usermapper:
1
2
3
4
5
6
7
|
/** * user 表數(shù)據(jù)庫(kù)控制層接口 */ public interface usermapper extends basemapper<user> { @select ( "selectuserlist" ) list<user> selectuserlist(pagination page,string state); } |
dao接口需要實(shí)現(xiàn)basemapper,這樣就能夠使用封裝好的很多通用方法,另外也可以自己編寫(xiě)方法,@select注解引用自第三步的usermapper文件
3.新建usermapper配置文件:
1
2
3
4
5
6
7
8
9
10
11
|
<?xml version= "1.0" encoding= "utf-8" ?> <!doctype mapper public "-//mybatis.org//dtd mapper 3.0//en" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <mapper namespace= "com.baomidou.springmvc.mapper.system.usermapper" > <!-- 通用查詢(xún)結(jié)果列--> <sql id= "base_column_list" > id, name, age </sql> <select id= "selectuserlist" resulttype= "user" > select * from sys_user where state=#{state} </select> </mapper> |
4.新建service層類(lèi)userservice:
1
2
3
4
5
6
7
8
9
10
11
12
|
/** * * user 表數(shù)據(jù)服務(wù)層接口實(shí)現(xiàn)類(lèi) * */ @service public class userservice extends serviceimpl<usermapper, user>{ public page<user> selectuserpage(page<user> page, string state) { page.setrecords(basemapper.selectuserlist(page,state)); return page; } } |
userservice繼承了serviceimpl類(lèi),mybatis-plus通過(guò)這種方式為我們注入了usermapper,這樣可以使用service層默認(rèn)為我們提供的很多方法,也可以調(diào)用我們自己在dao層編寫(xiě)的操作數(shù)據(jù)庫(kù)的方法.page類(lèi)是mybatis-plus提供分頁(yè)功能的一個(gè)model,繼承了pagination,這樣我們也不需要自己再編寫(xiě)一個(gè)page類(lèi),直接使用即可.
5,新建controller層usercontroller
1
2
3
4
5
6
7
8
9
10
11
|
@controller public class usercontroller extends basecontroller { @autowired private iuserservice userservice; @responsebody @requestmapping ( "/page" ) public object selectpage(model model){ page page= new page( 1 , 10 ); page = userservice.selectuserpage(page, "normal" ); return page; } |
以上就完成了一個(gè)基本的功能,下面來(lái)看一下它的條件構(gòu)建器.
mybatis-plus的條件構(gòu)建器
首先看一個(gè)條件構(gòu)建器實(shí)例的簡(jiǎn)單實(shí)用.
1
2
3
4
5
6
7
8
9
|
public void test(){ entitywrapper ew= new entitywrapper(); ew.setentity( new user()); string name= "wang" ; integer age= 16 ; ew.where( "name = {0}" ,name).andnew( "age > {0}" ,age).orderby( "age" ); list<user> list = userservice.selectlist(ew); page page2 = userservice.selectpage(page, ew); } |
這里使用了一個(gè)條件包裝類(lèi)entitywrapper,來(lái)進(jìn)行對(duì)sql語(yǔ)句的拼裝,原理也很好理解,上面的代碼中,第一個(gè)list查詢(xún)的結(jié)果就是查詢(xún)數(shù)據(jù)庫(kù)中name=wang并且age>16歲的所有記錄并按照age排序.而第二個(gè)查詢(xún)就是再多加一個(gè)分頁(yè)的功能.
基本上來(lái)說(shuō),使用entitywrapper可以簡(jiǎn)單地完成一些條件查詢(xún),但如果查詢(xún)方法使用頻率很高的話還是建議自己寫(xiě)在usermapper里.
那么自定義的mapper方法能不能使用entitywrapper呢,當(dāng)然也是可以的.
文檔中給了一個(gè)這樣的例子.
1.在mappper中定義:
list<user> selectmypage(rowbounds rowbounds, @param("ew") wrapper<t> wrapper);
2.在mapper文件中定義:
1
2
3
|
<select id= "selectmypage" resulttype= "user" > select * from user ${ew.sqlsegment} </select> |
對(duì)于entitymapper的條件拼接,基本可以實(shí)現(xiàn)sql中常用的where,and,or,groupby,orderby等語(yǔ)法,具體構(gòu)建方法可以靈活組合.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
@test public void testtsql11() { /* * 實(shí)體帶查詢(xún)使用方法 輸出看結(jié)果 */ ew.setentity( new user( 1 )); ew.where( "name={0}" , "'zhangsan'" ).and( "id=1" ) .ornew( "status={0}" , "0" ).or( "status=1" ) .notlike( "nlike" , "notvalue" ) .andnew( "new=xx" ).like( "hhh" , "ddd" ) .andnew( "pwd=11" ).isnotnull( "n1,n2" ).isnull( "n3" ) .groupby( "x1" ).groupby( "x2,x3" ) .having( "x1=11" ).having( "x3=433" ) .orderby( "dd" ).orderby( "d1,d2" ); system.out.println(ew.getsqlsegment()); } |
參考文檔
總結(jié)
以上所述是小編給大家介紹的mybatis plus工具快速入門(mén)使用教程,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
原文鏈接:https://www.cnblogs.com/dnxf/p/9086961.html