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

您的位置:首頁技術文章
文章詳情頁

MyBatis還是JPA?終于有答案了

瀏覽:20日期:2023-10-22 11:17:10

對于一個和數據庫打交道的程序員來說,很快會面臨著一個艱難的選擇。到底是選擇MyBatis還是JPA呢?

很多人說,技術選擇,都要根據需求來,這個沒錯。但是,除了需求,還有很重要的一個環節,那就是隊友的水平。如果你選擇了一些比較高級的技術,那么就是在給整個團隊埋坑。

JPA的抽象層次更高,代碼寫起來也更簡潔,但是它一點都不簡單。雖然經過了多次的培訓,我呆過的幾個團隊,還是把它用的和屎一樣。

我扔掉了JPA

我仔細想了一下,有下面幾點原因,造成了JPA在很多團隊根本就玩不下去。

JPA適合業務模型固定的場景,適合比較穩定的需求。但是國內這種朝三暮四的需求風格,產品經理這種傳話筒式的設計模式,造成了需求的泛濫和不確定。JPA在這種模式下就是渣。 JPA的技術要求比較高。不要懷疑,你剛開始用起里可能覺得非常簡單。但隨著你的深入使用,你會發現這是一個災難。里面的各種轉換和緩存,會把人繞暈。而大多數的快餐程序員是不想要了解這些的。 很多程序員很會寫SQL,所以很多SQL語句長的很胖,長的要命。業務混亂,多張表關聯,我甚至見過上百張業務表關聯的復雜業務。DBA無奈之下,通常都會有sql審核。JPA搞sql審核?還是弱了一點。

所以,不是JPA不好,而是它不符合國情而已。想要在公司內推行JPA,你需要給我一個穩定的產品團隊、一個牛X的技術團隊才行。

所以,大多數公司寧可寫一堆重復的、亂七八糟的Mybaits代碼,也不會輕易嘗試JPA,這是符合邏輯的,符合事物發展規律的。

所以,我們下面的文章就是來討論MyBatis的,來看一下Mybaits到底要怎么寫才算優雅。

MyBatis為什么不好用

優秀的程序員都是很懶的。所以很多人不想設計實體的sql。JPA可以直接根據Java的實體代碼,生成sql的庫表,這在使用Mybatis的人來看,是非常羨慕的。

使用MyBatis,要倒著來。需要先設計庫表,然后根據庫表反向生成一堆Java代碼和配置文件。

這個代碼生成器,就是mybatis-generator。

但是,請注意。這個生成器生成的代碼,有四種模式?。?!這就是最讓初學者難受的地方。如果你也是剛接觸MyBatis,強烈推薦只關注下面第一種模式。

MyBatis3 這種模式就是我們常用的方式,會生成domain類、Example類、mapper映射文件等。它生成的信息比較??攏?諶菁負蹺薹ǜ畝?6雜諳钅恐兇約盒吹?ql,一般都采用手寫的方式再寫一份,而不是改動原來的文件。 MyBatis3Simple 上面這種模式的簡易代碼生成模式,缺少一些東西,但很簡潔。對MyBatis沒有經驗,不推薦使用它。 MyBatis3DynamicSql 這是通過Builder模式實現的動態SQL特性,你還需要加入額外的jar包。加上它之后,其實和JPA是有點相似的。既然如此,那為何不直接使用JPA呢?所以這個DSQL雖然是默認的生成行為,但是非常不推薦。 MyBatis3Kotlin 這個不廢話。就是生成Kotlin版的一些配置和代碼信息。

所以,下面僅僅介紹MyBatis3模式的代碼生成。

要使用它,需要在pom.xml里加入它的依賴。

<dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <optional>true</optional> <scope>test</scope> <version>1.4.0</version></dependency>

我個人喜歡使用Java代碼來操作代碼生成這個過程,所以下面就是生成代碼的代碼。

public class MBGTool { public static void main(String[] args) throws Exception { List<String> warnings = new ArrayList<>(); boolean overwrite = true; InputStream configFile = MBGTool.class.getResourceAsStream('/generator/generatorConfig.xml'); ConfigurationParser cp = new ConfigurationParser(warnings); Configuration config = cp.parseConfiguration(configFile); DefaultShellCallback callback = new DefaultShellCallback(overwrite); MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings); myBatisGenerator.generate(null); }}

從代碼中,我們可以看到需要配置一個generatorConfig.xml文件,用來規定怎么生成代碼文件。

<!DOCTYPE generatorConfiguration PUBLIC '-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN' 'http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd'><generatorConfiguration> <context targetRuntime='MyBatis3'> <jdbcConnection driverClass='com.mysql.cj.jdbc.Driver' connectionURL='jdbc:mysql://localhost:3306/mbye' userId='root' password='root' /> <javaModelGenerator targetPackage='com.github.javarunfast.mbye.domain' targetProject='src/main/java'> <property name='enableSubPackages' value='true'/> <property name='trimStrings' value='true'/> </javaModelGenerator> <sqlMapGenerator targetPackage='com.github.javarunfast.mbye.mapper' targetProject='src/main/resources'/> <javaClientGenerator type='XMLMAPPER' targetPackage='com.github.javarunfast.mbye.mapper' targetProject='src/main/java'> <property name='enableSubPackages' value='true'/> </javaClientGenerator> <table tableName='test'/> </context></generatorConfiguration>

運行我們的MBGTool文件之后,就可以生成MyBatis的代碼了。

怎么寫代碼最優雅

但是,我這里并不是要推薦你使用這種模式。因為,它生成了一大堆無用的文件。假如你的項目使用了sonar這樣的代碼質量審查工具,你會發現很多飄紅的地方,還有那要命的覆蓋率問題。怎么辦?

經過我多年的摸索,我現在推薦一種非常好用的寫法。自從我采用了這種方式之后,就再也沒有換過。

第一、不需要代碼生成器了數據表的設計,還有domain的書寫,全部靠手工。這樣我們的代碼,如果有必要,還可以遷移到JPA上去。這種模式還能順便學習一下Java里面的數據類型,是如何和SQL里的數據類型一一對應的。在做表設計的時候,順便能夠了解一些背后的原理。

第二、不需要寫映射文件了生成器生成的東西,確實是有一堆無用的邏輯。比如我的某個數據表,根本不需要提供查詢所有和刪除這種動作,它還是默認提供了。

在這種簡約模式下,我們直接手寫Mapper文件,然后只聲明所需要的接口方法就可以了。

@Mapperpublic interface AccountBasicMapper { @Insert('AccountBasicMapper/insert.sql') void insert(@Param('r') AccountBasic record);}

可以看到,里面有一個Insert注解,我們傳入了一個具體的domain,然后,就可以在AccountBasicMapper目錄下的insert.sql文件里,書寫具體的sql語句了。

sql語句樣例如下:

INSERT INTO account_basic( account_id, nick_name, password, sex, state, photo_url, created, modified, version)VALUES ( <@p name='r.accountId'/>, <@p name='r.nickName'/>, <@p name='r.password'/>, <@p name='r.sex'/>, <@p name='r.state'/>, <@p name='r.photoUrl'/>, <@p name='r.created'/>, <@p name='r.modified'/>, <@p name='r.version'/>)

那么這是什么語法呢?它又是如何知道是這樣配置的呢?這就需要引入MyBatis的腳本語言配置功能。在這里,我們使用的freemark的模版。

不要忘了加入它的依賴。

<dependency> <groupId>org.mybatis.scripting</groupId> <artifactId>mybatis-freemarker</artifactId> <version>1.2.2</version></dependency>

然后,在yaml文件里做上相應的配置就ok了。

mybatis: check_config_location: false scripting-language-driver: freemarker: template-file: base-dir: mappers/ path-provider: includes-package-path: false separate-directory-per-mapper: false

這種方式的好處和壞處

我個人是非常喜歡這種模式的。因為它有下面幾個好處:

用什么寫什么,代碼量少,簡潔優雅。 SQL集中,不用分散在代碼里,xml里,或者注解里。方便DBA進行SQL審核。由于沒了xml的干擾,SQL反而更加簡潔了。 一個DAO方法一個sql文件,模式單一可控。 MyBatis的功能優勢可以全部發揮,無縫集成。

當然,缺點也是顯而易見的。

即使變了個參數,也要修改很多sql文件。 需要為每一個方法配一個sql文件,即使這是個很弱智的插入查詢方法。

不過,我并不認為這是個問題。每一個方法配備一個sql文件,代碼寫起來反而更加簡單了。當出現問題的時候,也不用根據邏輯進行跟蹤定位到拼接后的SQL語句。我現在,只需要拿到對應方法的SQL文件,就可以改吧改吧,直接在sql終端里執行調試。這樣,sql優化也變的簡單了。

當然,一個人一個習慣。我個人喜歡這種模式,而且在我的團隊里推行這種模式,發現運行的也很好。另外,程序員為了少寫重復的sql代碼,在設計Dao接口的時候,反而更加認真了。

這可能是一個額外的收獲吧。

到此這篇關于MyBatis還是JPA?終于有答案了的文章就介紹到這了,更多相關MyBatis還是JPA內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
午夜影院一区| 国产中文在线播放| 久久gogo国模啪啪裸体| 亚洲人成在线影院| 蜜桃91丨九色丨蝌蚪91桃色| 蜜臀91精品一区二区三区| 国产视频一区在线观看一区免费| av亚洲在线观看| 性欧美69xoxoxoxo| 国产亚洲在线观看| 亚洲区第一页| 欧美一区91| 精品国产一区二| 日韩精品影视| 久热精品在线| 国产精品极品| 欧美精品高清| 亚洲制服少妇| 久久国产三级| 精品欧美一区二区三区在线观看| 不卡视频在线| 青草国产精品| 人人香蕉久久| 日本一不卡视频| 美女视频黄免费的久久| 久久青草久久| 日韩精品亚洲专区| 亚洲91视频| 欧美一级二级三级视频| 成人羞羞在线观看网站| 免费观看久久久4p| 国产不卡精品| 在线亚洲免费| 亚洲精品麻豆| 欧美在线不卡| 亚洲狼人精品一区二区三区| 男人的天堂亚洲一区| 先锋亚洲精品| 深夜视频一区二区| 日本精品影院| 夜久久久久久| 国内在线观看一区二区三区| 免费久久精品视频| 一区二区小说| 日韩电影免费在线观看| 久久xxx视频| 日本欧美大码aⅴ在线播放| 91亚洲国产高清| 青青伊人久久| 亚洲视频二区| 欧美精品黄色| | 国产精品三上| 日韩国产欧美| 久久尤物视频| 国产精品毛片aⅴ一区二区三区| 美女尤物久久精品| 亚洲综合不卡| 狠狠色狠狠色综合日日tαg| 香蕉视频亚洲一级| 国产精品白丝一区二区三区| 亚洲一区二区av| 日韩1区2区3区| 日韩精品高清不卡| 国产图片一区| 国产精品伊人| 成人国产精品久久| 超碰在线99| 亚洲一级网站| 蜜臀a∨国产成人精品| 欧美一区二区三区久久| 国产激情一区| 日韩欧美一区二区三区免费观看| 91亚洲一区| 巨乳诱惑日韩免费av| 伊人精品视频| 久久免费黄色| 桃色av一区二区| 久久久久久久久久久妇女| 亚洲视频综合| 一级成人国产| 成人日韩av| 国产亚洲激情| 国产精品高清一区二区| 另类专区亚洲| 伊人精品久久| 日韩久久一区二区三区| 伊人www22综合色| 久久久久九九精品影院| 久久在线免费| 欧美日韩夜夜| 国产aⅴ精品一区二区三区久久| 天堂日韩电影| 日韩av字幕| 欧美亚洲精品在线| 日韩精品国产精品| 亚洲福利一区| 国产日产高清欧美一区二区三区| 国产精品成人一区二区不卡| 免费在线观看一区二区三区| 亚洲国产成人二区| 深夜福利一区| 成人免费电影网址| 欧美私人啪啪vps| 蜜臀av免费一区二区三区| 国产日韩亚洲| 日韩av免费| 国产日本精品| 综合国产精品| 欧美精品一区二区三区精品| 国产日产精品_国产精品毛片 | 亚洲欧美不卡| 成人亚洲欧美| 美女毛片一区二区三区四区最新中文字幕亚洲 | 99国产精品免费视频观看| 国产精品v日韩精品v欧美精品网站| 国产在线欧美| 一区二区精品伦理...| 麻豆传媒一区二区三区| 欧美日韩夜夜| 日韩区欧美区| 久热精品在线| 在线视频亚洲欧美中文| 老司机精品久久| 亚洲欧美日韩综合国产aⅴ| 国产精品xx| 欧美天堂视频| 欧美福利一区| 好吊视频一区二区三区四区| 欧美二三四区| 婷婷成人综合| 中文日韩欧美| 天使萌一区二区三区免费观看| 亚洲成人精选| 日韩专区一卡二卡| 蜜桃av一区二区在线观看| 丝袜脚交一区二区| 日韩高清电影免费| 久久免费福利| 四虎影视精品| 婷婷综合在线| 日韩精品91亚洲二区在线观看| 国产图片一区| 亚洲www啪成人一区二区| 国产精品视区| 国产午夜久久av| 国产成人精品亚洲日本在线观看| 性欧美69xoxoxoxo| 日韩精品一区二区三区免费视频| 国产精品成人**免费视频| 久久精品91| 少妇精品久久久一区二区| 久久永久免费| 亚洲一区av| 日韩电影二区| 巨乳诱惑日韩免费av| 精品国产午夜肉伦伦影院| 激情婷婷综合| 国产精品麻豆成人av电影艾秋| 久久一区二区三区喷水| 久久狠狠久久| 99视频精品| 精品中国亚洲| 美女尤物久久精品| 成人羞羞视频播放网站| 国产精品中文字幕制服诱惑| 欧美 日韩 国产一区二区在线视频 | 黄色不卡一区| 精品国产精品国产偷麻豆| 麻豆亚洲精品| 日韩电影二区| 国产欧美一级| 另类国产ts人妖高潮视频| 在线手机中文字幕| 国产三级一区| 午夜亚洲福利| 亚洲激情精品| 青青久久av| 久久精品福利| 欧美日韩亚洲一区在线观看| 老牛影视一区二区三区| 久久中文视频| 成人羞羞视频播放网站| 91视频一区| 成人在线视频免费看| 国产日韩三级| 国产精品成人3p一区二区三区| 亚洲va久久| 四虎国产精品免费久久| 综合一区av| 蜜臀av一区二区在线免费观看| 亚洲精品1区| 国产精品嫩草99av在线| 久久精品国内一区二区三区水蜜桃| 国产精品天天看天天狠| 国产精品亚洲人成在99www | 亚洲一区欧美二区| 久久午夜精品| 成人精品天堂一区二区三区| 欧美一级久久|