一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|JavaScript|易語言|

服務器之家 - 編程語言 - Java教程 - MyBatis Plus工具快速入門使用教程

MyBatis Plus工具快速入門使用教程

2021-05-05 11:41帶妳訫飛 Java教程

這篇文章主要介紹了MyBatis Plus工具快速入門使用教程,需要的朋友可以參考下

mybatis-plus有什么特色

   1.代碼生成 2.條件構造器

    對我而言,主要的目的是使用它強大的條件構建器.  

快速使用步驟:

  1.添加pom文件依賴

?
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會自動維護mybatis以及mybatis-spring的依賴,所以不需要引入后兩者,避免發生版本沖突.

  2.修改配置文件

  將mybatis的sqlsessionfactory替換成mybatis-plus的即可,mybatis-plus只做了一些功能的擴展: 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<bean id="sqlsessionfactory" class="com.baomidou.mybatisplus.spring.mybatissqlsessionfactorybean">
  <property name="datasource" ref="datasource"/>
  <!-- 自動掃描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>
    <!-- 分頁插件配置 -->
    <bean id="paginationinterceptor" class="com.baomidou.mybatisplus.plugins.paginationinterceptor">
     <property name="dialecttype" value="mysql"/>
    </bean>
   </array>
  </property>
  <!-- 全局配置注入 -->
  <property name="globalconfig" ref="globalconfig" />
</bean>

  在上面的配置中,除了mybatis的常規配置,多了一個分頁插件的配置和全局配置,mybatis-plus提供了很方便的使用分頁的插件,還有一個全局配置如下:  

?
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`("數據庫id自增")
    input->`1`(用戶輸入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需要添加該項 -->
  <!-- <property name="dbtype" value="oracle" /> -->
  <!-- 全局表為下劃線命名設置 true -->
  <property name="dbcolumnunderline" value="true" />
 </bean>

  至此,配置工作就算大功告成了,接下來通過一個簡單的例子來感受一下它的使用.

  1.新建一個user表:

?
1
2
3
4
5
6
7
8
9
10
11
@tablename("user")
public class user implements serializable {
 /** 用戶id */
 private long id;
 /** 用戶名 */
 private string name;
 /** 用戶年齡 */
 private integer age;
 @tablefield(exist = false)
 private string state;
}

  這里有兩個注解需要注意,第一是@tablename("user"),它是指定與數據庫表的關聯,這里的注解意味著你的數據庫里應該有一個名為user的表與之對應,并且數據表的列名應該就是user類的屬性,對于user類中有而user表中沒有的屬性需要加第二個注解@tablefield(exist = false),表示排除user類中的屬性.

     2.新建dao層接口usermapper:

?
1
2
3
4
5
6
7
/**
 * user 表數據庫控制層接口
 */
public interface usermapper extends basemapper<user> {
 @select("selectuserlist")
 list<user> selectuserlist(pagination page,string state);
}

  dao接口需要實現basemapper,這樣就能夠使用封裝好的很多通用方法,另外也可以自己編寫方法,@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">
 <!-- 通用查詢結果列-->
 <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層類userservice:

?
1
2
3
4
5
6
7
8
9
10
11
12
/**
 *
 * user 表數據服務層接口實現類
 *
 */
@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類,mybatis-plus通過這種方式為我們注入了usermapper,這樣可以使用service層默認為我們提供的很多方法,也可以調用我們自己在dao層編寫的操作數據庫的方法.page類是mybatis-plus提供分頁功能的一個model,繼承了pagination,這樣我們也不需要自己再編寫一個page類,直接使用即可.

  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;
 }

   以上就完成了一個基本的功能,下面來看一下它的條件構建器.

mybatis-plus的條件構建器

  首先看一個條件構建器實例的簡單實用.

?
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);
 }

  這里使用了一個條件包裝類entitywrapper,來進行對sql語句的拼裝,原理也很好理解,上面的代碼中,第一個list查詢的結果就是查詢數據庫中name=wang并且age>16歲的所有記錄并按照age排序.而第二個查詢就是再多加一個分頁的功能.

  基本上來說,使用entitywrapper可以簡單地完成一些條件查詢,但如果查詢方法使用頻率很高的話還是建議自己寫在usermapper里.

  那么自定義的mapper方法能不能使用entitywrapper呢,當然也是可以的.

  文檔中給了一個這樣的例子.

  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>

   對于entitymapper的條件拼接,基本可以實現sql中常用的where,and,or,groupby,orderby等語法,具體構建方法可以靈活組合.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
@test
public void testtsql11() {
 /*
  * 實體帶查詢使用方法 輸出看結果
  */
 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());
}

 參考文檔

       mybaits-plus官方文檔

總結

以上所述是小編給大家介紹的mybatis plus工具快速入門使用教程,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

原文鏈接:https://www.cnblogs.com/dnxf/p/9086961.html

延伸 · 閱讀

精彩推薦
  • Java教程springboot整合EHCache的實踐方案

    springboot整合EHCache的實踐方案

    EhCache是一個純Java的進程內緩存框架,具有快速、精干等特點,是Hibernate中默認的CacheProvider。這篇文章給大家介紹了springboot整合EHCache的實踐方案,需要的...

    OnyWang10512021-03-23
  • Java教程在Java Web項目中添加定時任務的方法

    在Java Web項目中添加定時任務的方法

    在Java Web程序中加入定時任務,這里介紹兩種方式使用監聽器注入,使用Spring注解@Scheduled注入,需要的朋友可以參考下...

    東窗凝殘月11162021-03-25
  • Java教程[Spring MVC] -簡單表單提交實例

    [Spring MVC] -簡單表單提交實例

    本篇文章主要介紹了[Spring MVC] -簡單表單提交實例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。 ...

    橫渡2832020-07-12
  • Java教程IntelliJ IDEA創建maven多模塊項目(圖文教程)

    IntelliJ IDEA創建maven多模塊項目(圖文教程)

    這篇文章主要介紹了IntelliJ IDEA創建maven多模塊項目(圖文教程),非常具有實用價值,需要的朋友可以參考下...

    請叫我大表哥10532021-01-10
  • Java教程Java中Map的遍歷方法及性能測試

    Java中Map的遍歷方法及性能測試

    這篇文章主要介紹了Java中Map的遍歷方法及性能測試,本文講解對HashMap、TreeMap進行對比測試,給出測試代碼、測試結果和測試結論,需要的朋友可以參考下 ...

    junjie3382019-12-08
  • Java教程Java嵌套類和內部類詳解

    Java嵌套類和內部類詳解

    這篇文章主要介紹了Java嵌套類和內部類詳解,本文講解了什么是嵌套類及內部類、靜態嵌套類、在外部類中定義內部類、在方法中定義內部類、匿名內部類...

    junjie1842019-12-17
  • Java教程Java網絡編程教程之設置請求超時的方法

    Java網絡編程教程之設置請求超時的方法

    這篇文章主要給大家介紹了關于Java網絡編程教程之設置請求超時的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者工作具有一定的參考學習...

    iamgeektao8072021-03-06
  • Java教程從零開始學JAVA之可變參數

    從零開始學JAVA之可變參數

    本文是從零開始學JAVA的第一篇,屬于Java基礎知識介紹的第一部分,主要介紹Java的可變參數,非常使用,希望對大家有所幫助 ...

    hebedich2062019-12-03
主站蜘蛛池模板: 欧美贵妇videos办公室 | 午夜国产小视频 | 欧美亚洲国产精品久久第一页 | 国产成人a v在线影院 | 男人搡女人视频免费看 | 精品卡1卡2卡三卡免费网站 | 欧美日韩一区视频 | va在线视频| 毛片 ftp | 四虎影院在线免费 | 精品久久久久亚洲 | 国产精品亚洲综合久久 | 精品久久久久亚洲 | 免费观看无遮挡www的小视频 | 四虎最新免费网址 | 精品国产线拍大陆久久尤物 | 女学生被老师调教在教室 | 精品无码人妻一区二区免费AV | 日本视频在线免费播放 | 国产大片视频免费观看 | 四虎播放器| 女人扒开下面让男人桶爽视频 | 精品精品国产自在久久高清 | 欧美老骚 | 明星裸乳照无奶罩 | 大胸美女被c | 国产麻豆精品原创 | 免费高清www动漫视频播放器 | 国产亚洲精品看片在线观看 | 亚洲久操| 日麻逼 | 91精品国产亚洲爽啪在线影院 | 男人猛激烈吃奶gif动态图 | 午夜伦理:伦理片 | 日本护士xxxx爽爽爽 | 日韩精品在线视频观看 | 成年人黄色录像 | 99久久精品无码一区二区毛片 | 国产高清日韩 | 美女大乳被捏羞羞漫画 | 欧美性bbbbbxxxxxxx |