日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

Java技术:干掉 XML配置文件,新出的 Fluent Mybatis 技术真香!

發布時間:2023/12/10 asp.net 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java技术:干掉 XML配置文件,新出的 Fluent Mybatis 技术真香! 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

使用fluent mybatis可以不用寫具體的xml文件,通過java api可以構造出比較復雜的業務sql語句,做到代碼邏輯和sql邏輯的合一。

不再需要在Dao中組裝查詢或更新操作,在xml或mapper中再組裝參數。那對比原生Mybatis, Mybatis Plus或者其他框架,FluentMybatis提供了哪些便利呢?

需求場景設置

我們通過一個比較典型的業務需求來具體實現和對比下,假如有學生成績表結構如下:

create?table?`student_score` (id???????????bigint?auto_increment?comment?'主鍵ID'?primary?key,student_id???bigint????????????not?null?comment?'學號',gender_man???tinyint?default?0?not?null?comment?'性別,?0:女;?1:男',school_term??int???????????????null?comment?'學期',subject??????varchar(30)???????null?comment?'學科',score????????int???????????????null?comment?'成績',gmt_create???datetime??????????not?null?comment?'記錄創建時間',gmt_modified?datetime??????????not?null?comment?'記錄最后修改時間',is_deleted???tinyint?default?0?not?null?comment?'邏輯刪除標識' )?engine?=?InnoDB?default?charset=utf8;

現在有需求:

統計2000年三門學科('英語', '數學', '語文')及格分數按學期,學科統計最低分,最高分和平均分, 且樣本數需要大于1條,統計結果按學期和學科排序

我們可以寫SQL語句如下

select?school_term,subject,count(score)?as?count,min(score)???as?min_score,max(score)???as?max_score,avg(score)???as?max_score from?student_score where?school_term?>=?2000and?subject?in?('英語',?'數學',?'語文')and?score?>=?60and?is_deleted?=?0 group?by?school_term,?subject having?count(score)?>?1 order?by?school_term,?subject;

那上面的需求,分別用fluent mybatis, 原生mybatis 和 Mybatis plus來實現一番。

三者實現對比

使用fluent mybatis 來實現上面的功能

圖片

具體代碼

我們可以看到fluent api的能力,以及IDE對代碼的渲染效果。

換成mybatis原生實現效果

  • 定義Mapper接口

  • public?interface?MyStudentScoreMapper?{List<Map<String,?Object>>?summaryScore(SummaryQuery?paras); }
  • 定義接口需要用到的參數實體 SummaryQuery

  • @Data @Accessors(chain?=?true) public?class?SummaryQuery?{private?Integer?schoolTerm;private?List<String>?subjects;private?Integer?score;private?Integer?minCount; }
  • 定義實現業務邏輯的mapper xml文件

  • <select?id="summaryScore"?resultType="map"?parameterType="cn.org.fluent.mybatis.springboot.demo.mapper.SummaryQuery">select?school_term,subject,count(score)?as?count,min(score)?as?min_score,max(score)?as?max_score,avg(score)?as?max_scorefrom?student_scorewhere?school_term?>=?#{schoolTerm}and?subject?in<foreach?collection="subjects"?item="item"?open="("?close=")"?separator=",">#{item}</foreach>and?score?>=?#{score}and?is_deleted?=?0group?by?school_term,?subjecthaving?count(score)?>?#{minCount}order?by?school_term,?subject </select>
  • 實現業務接口(這里是測試類, 實際應用中應該對應Dao類)

  • @RunWith(SpringRunner.class) @SpringBootTest(classes?=?QuickStartApplication.class) public?class?MybatisDemo?{@Autowiredprivate?MyStudentScoreMapper?mapper;@Testpublic?void?mybatis_demo()?{//?構造查詢參數SummaryQuery?paras?=?new?SummaryQuery().setSchoolTerm(2000).setSubjects(Arrays.asList("英語",?"數學",?"語文")).setScore(60).setMinCount(1);List<Map<String,?Object>>?summary?=?mapper.summaryScore(paras);System.out.println(summary);} }

    總之,直接使用mybatis,實現步驟還是相當的繁瑣,效率太低。那換成mybatis plus的效果怎樣呢?

    換成mybatis plus實現效果

    mybatis plus的實現比mybatis會簡單比較多,實現效果如下

    圖片

    如紅框圈出的,寫mybatis plus實現用到了比較多字符串的硬編碼(可以用Entity的get lambda方法部分代替字符串編碼)。字符串的硬編碼,會給開發同學造成不小的使用門檻,個人覺的主要有2點:

  • 字段名稱的記憶和敲碼困難

  • Entity屬性跟隨數據庫字段發生變更后的運行時錯誤

  • 其他框架,比如TkMybatis在封裝和易用性上比mybatis plus要弱,就不再比較了。

    生成代碼編碼比較

    fluent mybatis生成代碼設置

    public?class?AppEntityGenerator?{static?final?String?url?=?"jdbc:mysql://localhost:3306/fluent_mybatis_demo?useSSL=false&useUnicode=true&characterEncoding=utf-8";public?static?void?main(String[]?args)?{FileGenerator.build(Abc.class);}@Tables(/**?數據庫連接信息?**/url?=?url,?username?=?"root",?password?=?"password",/**?Entity類parent?package路徑?**/basePack?=?"cn.org.fluent.mybatis.springboot.demo",/**?Entity代碼源目錄?**/srcDir?=?"spring-boot-demo/src/main/java",/**?Dao代碼源目錄?**/daoDir?=?"spring-boot-demo/src/main/java",/**?如果表定義記錄創建,記錄修改,邏輯刪除字段?**/gmtCreated?=?"gmt_create",?gmtModified?=?"gmt_modified",?logicDeleted?=?"is_deleted",/**?需要生成文件的表?(?表名稱:對應的Entity名稱?)?**/tables?=?@Table(value?=?{"student_score"}))static?class?Abc?{} }

    mybatis plus代碼生成設置

    public?class?CodeGenerator?{static?String?dbUrl?=?"jdbc:mysql://localhost:3306/fluent_mybatis_demo?useSSL=false&useUnicode=true&characterEncoding=utf-8";@Testpublic?void?generateCode()?{GlobalConfig?config?=?new?GlobalConfig();DataSourceConfig?dataSourceConfig?=?new?DataSourceConfig();dataSourceConfig.setDbType(DbType.MYSQL).setUrl(dbUrl).setUsername("root").setPassword("password").setDriverName(Driver.class.getName());StrategyConfig?strategyConfig?=?new?StrategyConfig();strategyConfig.setCapitalMode(true).setEntityLombokModel(false).setNaming(NamingStrategy.underline_to_camel).setColumnNaming(NamingStrategy.underline_to_camel).setEntityTableFieldAnnotationEnable(true).setFieldPrefix(new?String[]{"test_"}).setInclude(new?String[]{"student_score"}).setLogicDeleteFieldName("is_deleted").setTableFillList(Arrays.asList(new?TableFill("gmt_create",?FieldFill.INSERT),new?TableFill("gmt_modified",?FieldFill.INSERT_UPDATE)));config.setActiveRecord(false).setIdType(IdType.AUTO).setOutputDir(System.getProperty("user.dir")?+?"/src/main/java/").setFileOverride(true);new?AutoGenerator().setGlobalConfig(config).setDataSource(dataSourceConfig).setStrategy(strategyConfig).setPackageInfo(new?PackageConfig().setParent("com.mp.demo").setController("controller").setEntity("entity")).execute();} }

    FluentMybatis特性一覽

    圖片

    三者對比總結

    看完3個框架對同一個功能點的實現, 各位看官肯定會有自己的判斷,筆者這里也總結了一份比較。

    圖片IT技術分享社區個人博客網站:https://programmerblog.xyz文章推薦程序員效率:畫流程圖常用的工具程序員效率:整理常用的在線筆記軟件遠程辦公:常用的遠程協助軟件,你都知道嗎?51單片機程序下載、ISP及串口基礎知識硬件:斷路器、接觸器、繼電器基礎知識

    總結

    以上是生活随笔為你收集整理的Java技术:干掉 XML配置文件,新出的 Fluent Mybatis 技术真香!的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 亚洲综合三区 | 黄色成人在线免费观看 | 日韩av成人在线 | 免费日韩毛片 | 91国产丝袜在线播放 | 一二区在线视频 | 91麻豆精品国产 | 久久亚洲成人 | 在线免费av观看 | 天天添天天射 | 又黄又色 | 成人一区二区在线 | 亚洲图片在线播放 | 免费草逼网站 | 97精品超碰一区二区三区 | 色哟哟视频网站 | 精品国产免费观看 | 狠狠操天天干 | 国产三级精品三级在线 | 蜜桃av噜噜一区二区三区小说 | 免费超爽大片黄 | 成人无遮挡 | 日韩成人av网 | 男生操女生在线观看 | 久久精品观看 | 久久国产成人 | 丁香av | 少妇全黄性生交片 | 99久久久无码国产精品性青椒 | 一区二区三区视频 | 日韩在线观看视频一区 | 91中文在线观看 | 日本黄色高清 | 免费看欧美一级特黄a大片 国产免费的av | 国产精品久久久一区二区三区 | 久操精品在线 | 国产一级大片在线观看 | 欧美性做爰猛烈叫床潮 | 亚洲视频网址 | 乱色熟女综合一区二区三区 | 亚洲激情免费视频 | 日韩久久精品 | 超碰.com | 97人妻精品一区二区三区 | 不卡的av| 99热这| 男女草比视频 | 在线观看jizz | 草草影院最新地址 | 欧美成人h版 | av中文字幕网| 日本va欧美va国产激情 | 日韩在线一级片 | 亚洲中文字幕无码爆乳av | 国产成人午夜精品无码区久久 | 色偷偷欧美 | 色666| 蜜桃tv一区二区三区 | 久久久久久欧美精品se一二三四 | 婷婷亚洲激情 | 粉嫩av一区 | 激情五月婷婷丁香 | 欧美黄色性生活 | 欧美久久久久久久久久 | 九九av在线 | 黄色片aaaa| 人人爽爽爽 | 韩国无码一区二区三区精品 | 一级特黄毛片 | 五月婷婷综合网 | aaaaaa毛片| 在线观看中文字幕 | 懂色av一区二区三区在线播放 | 性大片潘金莲裸体 | 久久精品这里 | 免费拍拍拍网站 | 日韩av男人的天堂 | 人妻丰满熟妇无码区免费 | 乱子伦视频在线看 | 精人妻无码一区二区三区 | 日本在线视频一区二区 | 久久综合亚洲色hezyo国产 | a级网站在线观看 | 亚色视频在线观看 | 夜夜嗨av一区二区三区 | 日韩福利视频在线观看 | 大尺度做爰啪啪床戏 | 四虎伊人| 黄色片成年人 | 98堂 最新网名 | 成人在线免费视频观看 | 狠狠插狠狠操 | 亚洲综合大片69999 | 啪视频在线观看 | 国产精品一级片 | 国产又粗又长又大视频 | 免费毛片小视频 | 中文字幕一区二区人妻 | 久久精品国产77777蜜臀 |