日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Fluent Mybatis快速入門詳細(xì)教程

瀏覽:39日期:2023-10-18 11:55:18

使用fluent mybatis可以不用寫具體的xml文件,通過java api可以構(gòu)造出比較復(fù)雜的業(yè)務(wù)sql語句,做到代碼邏輯和sql邏輯的合一。 不再需要在Dao中組裝查詢或更新操作,在xml或mapper中再組裝參數(shù)。喜歡的朋友可以閱讀這篇文章 http://www.jb51.net/article/218884.htm

對底層數(shù)據(jù)表關(guān)聯(lián)關(guān)系的處理,我們總是繞不開什么一對一,一對多,多對多這里比較煩人的關(guān)系。 業(yè)界優(yōu)秀的ORM框架也都給出了自己的答案,簡單來說就以下幾種方式:

hibernate和JPA對開發(fā)基本屏蔽了底層數(shù)據(jù)的處理,只需要在model層設(shè)置數(shù)據(jù)級聯(lián)關(guān)系即可。但這種設(shè)置也往往是噩夢的開始。mybatis 提供了簡單的@One @Many注解,然后編寫xml映射關(guān)系來提供級聯(lián)處理。還有一種就是干脆不依賴框架,直接應(yīng)用自己掌控。因?yàn)镕luentMybatis是基于mybatis上做封裝和擴(kuò)展的,所以這里主要聊聊mybatis處理的方式,以及給出FluentMybatis的解放方案。

那么就可以建以下3張表:

數(shù)據(jù)字典

CREATE TABLE t_member(id bigint(21) unsigned auto_increment primary key COMMENT ‘主鍵id’,user_name varchar(45) DEFAULT NULL COMMENT ‘名字’,is_girl tinyint(1) DEFAULT 0 COMMENT ‘0:男孩; 1:女孩’,age int DEFAULT NULL COMMENT ‘年齡’,school varchar(20) DEFAULT NULL COMMENT ‘學(xué)校’,gmt_created datetime DEFAULT NULL COMMENT ‘創(chuàng)建時(shí)間’,gmt_modified datetime DEFAULT NULL COMMENT ‘更新時(shí)間’,is_deleted tinyint(1) DEFAULT 0 COMMENT ‘是否邏輯刪除’) ENGINE = InnoDBCHARACTER SET = utf8 COMMENT = ‘成員表:女孩或男孩信息’;CREATE TABLE t_member_love(id bigint(21) unsigned auto_increment primary key COMMENT ‘主鍵id’,girl_id bigint(21) NOT NULL COMMENT ‘member表外鍵’,boy_id bigint(21) NOT NULL COMMENT ‘member表外鍵’,status varchar(45) DEFAULT NULL COMMENT ‘狀態(tài)’,gmt_created datetime DEFAULT NULL COMMENT ‘創(chuàng)建時(shí)間’,gmt_modified datetime DEFAULT NULL COMMENT ‘更新時(shí)間’,is_deleted tinyint(2) DEFAULT 0 COMMENT ‘是否邏輯刪除’) ENGINE = InnoDBCHARACTER SET = utf8 COMMENT = ‘成員戀愛關(guān)系’;CREATE TABLE t_member_favorite(id bigint(21) unsigned auto_increment primary key COMMENT ‘主鍵id’,member_id bigint(21) NOT NULL COMMENT ‘member表外鍵’,favorite varchar(45) DEFAULT NULL COMMENT ‘愛好: 電影, 爬山, 徒步…’,gmt_created datetime DEFAULT NULL COMMENT ‘創(chuàng)建時(shí)間’,gmt_modified datetime DEFAULT NULL COMMENT ‘更新時(shí)間’,is_deleted tinyint(2) DEFAULT 0 COMMENT ‘是否邏輯刪除’) ENGINE = InnoDBCHARACTER SET = utf8 COMMENT = ‘成員愛好’;

添加項(xiàng)目Maven依賴具體pom.xml文件

代碼生成

public class AppEntityGenerator {static final String url = “jdbc:mysql://localhost:3306/fluent_mybatis_demo?useSSL=false&useUnicode=true&characterEncoding=utf-8”;/*** 生成代碼的package路徑*/static final String basePackage = “cn.org.fluent.mybatis.many2many.demo”;public static void main(String[] args) { FileGenerator.build(Noting.class);}@Tables( /** 數(shù)據(jù)庫連接信息 **/ url = url, username = 'root', password = 'password', /** Entity類parent package路徑 **/ basePack = basePackage, /** Entity代碼源目錄 **/ srcDir = 'example/many2many_demo/src/main/java', /** 如果表定義記錄創(chuàng)建,記錄修改,邏輯刪除字段 **/ gmtCreated = 'gmt_create', gmtModified = 'gmt_modified', logicDeleted = 'is_deleted', /** 需要生成文件的表 ( 表名稱:對應(yīng)的Entity名稱 ) **/ tables = @Table(value = {'t_member', 't_member_love', 't_member_favorite'}, tablePrefix = 't_'))static class Noting {}}

這樣就生成了3個(gè)Entity類: MemberEntity, MemberFavoriteEntity, MemberLoveEntity。

關(guān)系分析

現(xiàn)在我們來理一理這里面的關(guān)系

一對多: 一個(gè)成員可以有多個(gè)愛好多對多: 一個(gè)成員可以有多個(gè)男女朋友(前任+現(xiàn)任)一對一: 一個(gè)成員只能有一個(gè)現(xiàn)任男女朋友mybatis處理手法mybatis提供了@One 和 @Many的注解來處理簡單(只有主鍵和外鍵依賴)的一對一,和一對多的關(guān)系 具體到上面的關(guān)系,mybatis只能關(guān)聯(lián)查詢成員的愛好,對帶條件的(不是只通過外鍵)現(xiàn)任男女朋友的一對一也沒有辦法處理。

我這里就不具體展開mybatis的配置語法了,感興趣讀者可以看下下面文章:

Mybatis一對多、多對一處理

Mybatis傳遞多個(gè)參數(shù)進(jìn)行SQL查詢的用法

MyBatis注解 & 多對一、一對多

MyBatis系列4:一對一,一對多,多對多查詢及延遲加載(N+1問題)分析

鑒于mybatis只能處理簡單的關(guān)聯(lián)關(guān)系,fluent mybatis就沒有直接封裝mybatis的處理方式,那fluent mybatis是如何處理上述的關(guān)聯(lián)關(guān)系的。 我們先從mybatis也可以處理的一對多的愛好列表入手

一對多的愛好列表處理fluent mybatis要根據(jù)MemberEntity自動(dòng)返回對應(yīng)的愛好列表,需要下面幾個(gè)設(shè)置:

MemberEntity繼承RichEntity基類在MemberEntity類里面增加方法 findMyFavorite()給findMyFavorite方法加上注解 @RefMethod在注解中增加關(guān)聯(lián)關(guān)系: “memberId=id”,意思是 MemberFavoriteEntity.memberId等于MemberEntity.id具體代碼片段如下, 所有這些操作都可以通過代碼生成,這里手工添加僅僅是為了講解

public class MemberEntity extends RichEntity implements IEntity {// …/*** 我的愛好列表** @return*/@RefMethod(“memberId=id”)public List findMyFavorite() {return super.loadCache(“findMyFavorite”, MemberEntity.class);}}

好了,我們已經(jīng)建立好通過Member實(shí)例查詢愛好列表的功能了,重新編譯項(xiàng)目 在generated-sources目錄下面,會多出一個(gè)文件: Refs

/***Refs:o - 查詢器,更新器工廠類單例引用o - 應(yīng)用所有Mapper Bean引用o - Entity關(guān)聯(lián)對象延遲加載查詢實(shí)現(xiàn)@author powered by FluentMybatis*/public abstract class Refs extends EntityRefQuery {public List findMyFavoriteOfMemberEntity(MemberEntity entity) {return memberFavoriteMapper.listEntity(new MemberFavoriteQuery().where.memberId().eq(entity.getId()).end());}}

在這個(gè)類里面自動(dòng)生成了一個(gè)方法: findMyFavoriteOfMemberEntity, 入?yún)⑹荕emberEntity, 出參是List, 實(shí)現(xiàn)里面根據(jù)member的id查詢了成員的所有愛好。

增加Spring Bean我們新建一個(gè)類: AllRelationQuery (名稱根據(jù)你的喜好和業(yè)務(wù)隨便取), 繼承Refs, 并把AllRelationQuery加入Spring管理即可。

@Servicepublic class AllRelationQuery extends Refs {}

老套路,寫個(gè)測試驗(yàn)證下

@RunWith(SpringRunner.class)@SpringBootTest(classes = Application.class)public class FindMemberFavoriteTest {@Autowiredprivate MemberMapper memberMapper;@Beforepublic void setup() { // 省略數(shù)據(jù)準(zhǔn)備部分}@Testpublic void findMyFavorite() { MemberEntity member = memberMapper.findById(1L); List<MemberFavoriteEntity> favorites = member.findMyFavorite(); System.out.println('愛好項(xiàng): ' + favorites.size());}}

查看控制臺log輸出

DEBUG - ==> Preparing: SELECT id, …, user_name FROM t_member WHERE id = ?DEBUG - > Parameters: 1(Long)DEBUG - < Total: 1DEBUG - ==> Preparing: SELECT id, …, member_id FROM t_member_favorite WHERE member_id = ?DEBUG - > Parameters: 1(Long)DEBUG - < Total: 2愛好項(xiàng): 2

如日志所示,F(xiàn)luent Mybatis按照預(yù)期返回了愛好列表。

給一對多關(guān)系添點(diǎn)油加點(diǎn)醋做過業(yè)務(wù)系統(tǒng)的同學(xué)都知道,數(shù)據(jù)庫中業(yè)務(wù)數(shù)據(jù)一般會有一個(gè)邏輯刪除標(biāo)識,按照上述邏輯查詢出來的數(shù)據(jù),我們會把已經(jīng)廢棄(邏輯刪除掉)的愛好也一并查詢出來了,那我們?nèi)绾沃徊樵兂鑫催壿媱h除(is_deleted=0)的愛好列表呢。

如果采用mybatis的方案,那我們只能聳聳肩,攤開雙手說: “愛莫能助,你自己寫SQL實(shí)現(xiàn)吧”, 但fluent mybatis對這類場景的支持的很好,我們只要給@RefMethod注解值加點(diǎn)條件就可以了, MemberFavoriteEntity.memberId=MemberEntity.id并且Favorite的邏輯刪除標(biāo)識和Member表一樣,具體定義如下:

public class MemberEntity extends RichEntity implements IEntity {@RefMethod(“memberId=id && isDeleted=isDeleted”)public List findMyFavorite() {return super.loadCache(“findMyFavorite”, MemberEntity.class);}}

重新編譯項(xiàng)目,觀察Refs代碼

public abstract class Refs extends EntityRefQuery {public List findMyFavoriteOfMemberEntity(MemberEntity entity) {return memberFavoriteMapper.listEntity(new MemberFavoriteQuery().where.isDeleted().eq(entity.getIsDeleted()).and.memberId().eq(entity.getId()).end());}}

查詢條件上帶上了邏輯刪除條件

跑測試,看log

DEBUG - ==> Preparing: SELECT id, …, user_name FROM t_member WHERE id = ?DEBUG - > Parameters: 1(Long)DEBUG - < Total: 1DEBUG - ==> Preparing: SELECT id, …, member_id FROM t_member_favoriteWHERE is_deleted = ?AND member_id = ?DEBUG - > Parameters: false(Boolean), 1(Long)DEBUG - < Total: 2愛好項(xiàng): 2

FluentMybatis輕松處理了多條件關(guān)聯(lián)的一對多關(guān)系, 這個(gè)在業(yè)務(wù)中不僅僅限定于邏輯刪除, 還可以推廣到部署環(huán)境標(biāo)識(deploy_env), 租戶關(guān)系等條件上,還有只有你業(yè)務(wù)中才用到的狀態(tài)相關(guān)的關(guān)系上。

Fluent Mybatis對多對多關(guān)系處理fluent mybatis可以輕松處理一對一,一對多的簡單和多條件的關(guān)聯(lián)關(guān)系,但對多對多也沒有提供自動(dòng)化代碼生成的處理手段。 因?yàn)槎鄬Χ啵举|(zhì)上涉及到3張表, A表, B表,AB關(guān)聯(lián)表。 但fluent mybatis還是提供了半自動(dòng)手段,對這類場景進(jìn)行了支持,比如我們需要MemberEntity中返回所有前任戀人列表。

在MemberEntity中定義方法: exFriends()

public class MemberEntity extends RichEntity implements IEntity {/*** 前任男(女)朋友列表** @return*/@RefMethodpublic List findExFriends() {return super.loadCache(“findExFriends”, MemberEntity.class);}}

和上面的自動(dòng)化的一對多關(guān)系有個(gè)區(qū)別,@RefMethod上沒有設(shè)置查詢條件,我們重新編譯項(xiàng)目。 我們觀察Refs類,除了剛才的findMyFavoriteOfMemberEntity方法實(shí)現(xiàn)外,還多出一個(gè)抽象方法: findExFriendsOfMemberEntity

public abstract class Refs extends EntityRefQuery {/*** 返回前任男(女)朋友列表*/public abstract List findExFriendsOfMemberEntity(MemberEntity entity);}

在動(dòng)手實(shí)現(xiàn)代碼前,我們先分析一下混亂的男女朋友關(guān)系在member表上,我們使用了一個(gè)性別字段 is_girl來區(qū)別是男的還是女的, 在戀愛關(guān)系表上,分別有2個(gè)外鍵girl_id, boy_id來標(biāo)識一對戀人關(guān)系。 這樣,如果member是女的,要查詢所有前任男朋友,那么sql語句就如下:

select * from t_memberwhere is_deleted=0and id in (select boy_id from t_memeber_lovewhere status = ‘前任’and girl_id = ? – 女孩idand is_deleted = 0)

如果member是男的,要查詢所有前任女朋友,那么sql語句條件就要倒過來:

select * from t_memberwhere is_deleted=0and id in (select girl_id from t_memeber_lovewhere status = ‘前任’and boy_id= ? – 男孩idand is_deleted = 0)

實(shí)現(xiàn)查詢前男(女)朋友列表功能一般來說,為了實(shí)現(xiàn)上面的分支查詢,在mybatis的xml文件中需要配置 這樣的標(biāo)簽代碼分支, 或者在java代碼中實(shí)現(xiàn) if(…){}else{}的代碼邏輯分支。 那我們來看看fluent mybatis時(shí)如何實(shí)現(xiàn)上述查詢的呢?我們就可以在剛才定義的Refs子類上實(shí)現(xiàn)findExFriendsOfMemberEntity自己的邏輯。

@Servicepublic class AllRelationQuery extends Refs {@Overridepublic List findExFriendsOfMemberEntity(MemberEntity entity) {MemberQuery query = new MemberQuery().where.isDeleted().isFalse().and.id().in(MemberLoveQuery.class, q -> q.select(entity.getIsGirl() ? boyId.column : girlId.column).where.status().eq(“前任”).and.isDeleted().isFalse().and.girlId().eq(entity.getId(), o -> entity.getIsGirl()).and.boyId().eq(entity.getId(), o -> !entity.getIsGirl()).end()).end();return memberMapper.listEntity(query);}}

寫測試看log

@RunWith(SpringRunner.class)@SpringBootTest(classes = Application.class)public class FindExFriendsTest {@Autowiredprivate MemberMapper memberMapper;@Testpublic void findExBoyFriends() { MemberEntity member = memberMapper.findById(1L); System.out.println('是否女孩:' + member.getIsGirl()); List<MemberEntity> boyFriends = member.findExFriends(); System.out.println(boyFriends);}}

控制臺日志

DEBUG - ==> Preparing: SELECT id, …, user_name FROM t_member WHERE id = ?DEBUG - > Parameters: 1(Long)DEBUG - < Total: 1是否女孩:trueDEBUG - ==> Preparing: SELECT id, …, user_name FROM t_memberWHERE is_deleted = ?AND id IN (SELECT boy_idFROM t_member_loveWHERE status = ?AND is_deleted = ?AND girl_id = ?)DEBUG - > Parameters: false(Boolean), 前任(String), false(Boolean), 1(Long)DEBUG - < Total: 1[MemberEntity(id=2, gmtModified=Sun Nov 08 12:31:57 CST 2020, isDeleted=false, age=null, gmtCreated=null, isGirl=false, school=null, userName=mike)]

如日志所示,在查詢前男友列表是,條件會根據(jù)Member的是否是女孩進(jìn)行分支切換,這也是fluent mybatis動(dòng)態(tài)條件強(qiáng)大的地方。

到此這篇關(guān)于FluentMybatis快速入門詳細(xì)教程的文章就介紹到這了,更多相關(guān)Fluent Mybatis入門內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本在线不卡视频一二三区| 91亚洲成人| 亚洲午夜精品久久久久久app| 精品国产精品久久一区免费式 | 久久精品资源| 欧美国产不卡| 久久久久久色| 国产欧美日韩在线一区二区| 亚洲精品观看| 日韩成人午夜精品| 国产精品羞羞答答在线观看| 麻豆传媒一区二区三区| 精品美女久久| 久久精品欧美一区| 国产一级久久| 日韩精品一页| 美日韩一区二区三区| 中文在线中文资源| 欧美日韩国产传媒| 亚洲精品九九| 精品亚洲精品| 欧美精品羞羞答答| 亚洲三级毛片| 国产精品一区二区三区美女 | 在线精品国产亚洲| 欧美日韩一区自拍| 国产成人免费视频网站视频社区| 91亚洲成人| 亚洲黄色在线| 日本高清久久| 国产成人精选| 精品欧美久久| 欧美日韩中出| 国产成人精品一区二区免费看京 | 亚洲精品进入| 精品视频免费| 婷婷激情图片久久| 日韩二区在线观看| 欧美羞羞视频| 亚洲三级网址| 国产精品伦理久久久久久| 亚洲精品一区二区妖精| 欧美天堂一区二区| 日韩精品免费一区二区三区| 亚洲一二三区视频| 国产精品不卡| 亚洲欧洲日本mm| 国产色99精品9i| 999久久久91| 日韩高清三区| 日韩av一级| **爰片久久毛片| 久久精品卡一| 国产调教精品| 亚洲精品a级片| 国产极品一区| 免费精品视频| 国产aⅴ精品一区二区三区久久| 最新亚洲一区| 日韩av专区| 亚洲综合福利| 麻豆精品蜜桃视频网站| 99在线精品视频在线观看| 久久超级碰碰| 国产精品视区| 欧美一级鲁丝片| 欧美亚洲国产日韩| 日韩一区二区免费看| 精品91福利视频| 日韩专区视频网站| jiujiure精品视频播放| 精品美女视频| 91麻豆精品激情在线观看最新| 国产麻豆久久| 久久久久久久久成人| 中文字幕亚洲在线观看| 97精品一区二区| 国产日韩欧美中文在线| 另类国产ts人妖高潮视频| 91看片一区| 免费看一区二区三区| 中文字幕成人| 国产一区视频在线观看免费| 精品国产一区二区三区av片| 日韩精品亚洲专区在线观看| 欧美特黄视频| 青青久久av| 另类小说一区二区三区| 日韩精品视频网| 久久免费大视频| 国产不卡精品| 国产美女亚洲精品7777| 中文字幕中文字幕精品| 国产精品人人爽人人做我的可爱| 三上悠亚国产精品一区二区三区| 国产精品videossex久久发布| 在线视频亚洲欧美中文| 夜夜嗨一区二区| 亚洲福利一区| 成人va天堂| xxxxx性欧美特大| 久久一区国产| 欧美日韩精品一区二区三区在线观看| 视频一区国产视频| 国产一区导航| 午夜视频精品| 日韩啪啪电影网| 在线亚洲人成| 91看片一区| 麻豆精品蜜桃| 精品丝袜在线| 日韩欧美精品| 成人片免费看| 中文字幕在线视频久| 精品三区视频| 丰满少妇一区| 国产91在线播放精品| 国产精品成人a在线观看| 精品三区视频| 日韩欧美在线中字| 久久精品导航| 久久亚洲在线| 国产在线欧美| 伊人久久婷婷| 视频一区国产视频| 中文字幕av一区二区三区四区| 亚洲一区二区三区在线免费| 亚洲精品一级| 欧美日韩午夜电影网| 国产精品一国产精品k频道56| 国产欧美日韩一区二区三区四区| 欧美片网站免费| 久久一区国产| 日韩国产综合| 91精品电影| 蜜臀久久99精品久久久久宅男| 性欧美长视频| 日韩一区二区三区精品| 日韩不卡在线观看日韩不卡视频| 日韩av不卡在线观看| 国产欧美日韩一区二区三区四区 | 青草综合视频| 麻豆精品视频在线观看| 超碰99在线| 色婷婷精品视频| 亚洲激情精品| 日本视频中文字幕一区二区三区| 国产精品s色| 日韩国产一区| 久久www成人_看片免费不卡| 蜜桃视频免费观看一区| 日韩精品一区二区三区中文在线 | 亚洲91网站| 国产高清日韩| 欧美三级网址| 久久午夜精品| 国产伦理一区| 欧美日韩视频网站| 午夜一区在线| 国产乱子精品一区二区在线观看 | 日本视频一区二区| 久久久免费人体| 欧美亚洲国产一区| 亚洲精品影视| 国产一区国产二区国产三区| 不卡视频在线| 久久精品 人人爱| 日韩一区二区三区免费| 在线精品视频一区| 久久久亚洲欧洲日产| 亚洲一级二级| 欧美亚洲三区| 999精品一区| 亚洲精品国模| 91综合网人人| 亚洲+小说+欧美+激情+另类| 国产一区不卡| 蜜臀av亚洲一区中文字幕| 美女在线视频一区| 美女毛片一区二区三区四区 | 日韩综合一区二区三区| 成人国产精品久久| 日韩精品一二区| 成人污污视频| 免费人成在线不卡| 国产成人精品免费视| 免费不卡在线观看| 国产精品毛片一区二区在线看| 国产一区白浆| 麻豆mv在线观看| 日韩有吗在线观看| 人人香蕉久久| 久久黄色影视| 亚洲精品网址| 国产一区二区三区亚洲综合| 亚洲人妖在线| 亚洲一级网站| 色综合狠狠操| 日韩毛片一区| 国产精品美女久久久|