日韩性视频-久久久蜜桃-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 技术真香!的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    主站蜘蛛池模板: 久久一区二区三区四区 | 久久久国产片 | 欧美日韩爱爱 | 在线视频 一区二区 | 中国极品少妇xxxx | 精品国产免费视频 | 天天透天天操 | 欧美在线国产 | 国产在线日本 | www,av在线| 久久久久一区二区三区 | 91在线视频国产 | 久久综合社区 | av在线中文 | 啦啦啦视频在线观看 | 欧美情爱视频 | 国产1级片| 可以直接看的毛片 | 久久久精品一区二区涩爱 | 日韩av大片 | 女人一区二区三区 | 巨大乳の揉んで乳榨り奶水 | 男生和女生差差视频 | 欧美成人三级伦在线观看 | 狠狠爱亚洲| 午夜爱 | 一级黄色性片 | 国产麻豆乱码精品一区二区三区 | 自拍视频一区 | 亚洲自拍偷拍精品视频 | 成人av图片 | 狠狠v欧美v日韩v亚洲ⅴ | 91日本视频 | 日韩性生活大片 | 午夜片在线观看 | 国产综合精品久久久久成人影 | 黄色美女毛片 | 日本高清视频免费观看 | 污视频网站入口 | 国产视频1区2区3区 国产欧美一区二区精品性色99 | 催眠美妇肉奴系统 | 69av网站| 男女无套免费视频网站动漫 | 超污网站在线观看 | 国产精品网站视频 | 秋霞成人av | 朝鲜黄色片| 芒果视频污污 | 91免费视频播放 | 亚洲精品国偷拍自产在线观看蜜桃 | 天堂资源地址在线 | 日本熟妇色xxxxx日本免费看 | 国产精品手机在线 | jzzijzzij亚洲成熟少妇 | 精品在线观看一区 | 久久精品毛片 | 亚洲蜜臀av | 大胸美女网站 | 综合成人 | 久久国产加勒比精品无码 | 国产一区成人 | 精品国产视频一区二区三区 | 国产成人不卡 | 青青久操 | 日韩网站免费 | 少妇专区| 日韩av无码一区二区三区不卡 | 日日噜夜夜噜 | 国产精品福利片 | eeuss鲁片一区二区三区在线观看 | 日韩欧美亚洲国产 | 天天夜碰日日摸日日澡性色av | 美女调教视频 | 日韩免费福利视频 | 亚洲欧美日韩精品久久 | 新x8x8拨牐拨牐永久免费影库 | 国产精品黄色片 | 国产女同91疯狂高潮互磨 | 中文字幕色站 | 日本精品入口免费视频 | 亚洲一区免费 | 麻豆免费视频网站 | 天天cao在线 | 中文视频一区二区 | 熟女高潮一区二区三区 | 亚洲第三区 | 国产一区二区内射 | 国产日产欧美一区二区 | 人人草人人插 | 成a人片亚洲日本久久 | 一区二区网站 | 欧美日韩黄色一区二区 | 成人乱人乱一区二区三区 | 国内精品免费 | 国产无套内射又大又猛又粗又爽 | 一级免费av | 久久国产视频一区 | 天天干天天看 | ass亚洲尤物裸体pics |