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

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

Mybatis Generator逆向工程的使用詳細教程

瀏覽:212日期:2023-10-23 17:54:29

一、MyBatis Generator簡介

MyBatis Generator(MBG)是MyBatis和iBATIS的代碼生成器。它將為所有版本的MyBatis以及版本2.2.0之后的iBATIS版本生成代碼。它將審查數據庫表(或許多表),并將生成可用于訪問表的構件。這減少了設置對象和配置文件以與數據庫表交互的初始麻煩。MBG尋求對簡單CRUD(創建,檢索,更新,刪除)的大部分數據庫操作產生重大影響。您仍然需要為連接查詢或存儲過程手動編寫SQL和對象代碼。MyBatis Generator將生成:

與表結構匹配的Java POJO。這可能包括:

一個匹配表的主鍵的類(如果有主鍵) 一個匹配表的非主鍵字段的類(BLOB字段除外) 包含表的BLOB字段的類(如果表具有BLOB字段) 用于啟用動態選擇,更新和刪除的類

這些類之間存在適當的繼承關系。請注意,生成器可以配置為生成不同類型的POJO層次結構 - 例如,如果您愿意,可以選擇為每個表生成單個域對象。

MyBatis/iBATIS兼容的SQL Map XML文件。MBG為配置中的每個表上的簡單CRUD函數生成SQL。生成的SQL語句包括:

insert 插入 update by primary key 按主鍵更新 update by example (using a dynamic where clause) 通過條件更新(使用動態where子句) delete by primary key 按主鍵刪除 delete by example (using a dynamic where clause) 按條件刪除(使用動態where子句) select by primary key 按主鍵查詢 select by example (using a dynamic where clause) 按條件查詢(使用動態where子句) count by example 按條件查詢記錄總數

根據表結構的不同,這些語句有不同的變體(例如,如果表沒有主鍵,則MBG不會通過主鍵功能生成更新)。

適當使用上述對象的Java客戶端類。Java客戶端類的生成是可選的。MBG將為MyBatis 3.x生成以下類型的Java客戶端:

適用于MyBatis 3.x映射器基礎結構的映射器接口

MBG將為iBATIS 2.x生成以下類型的Java客戶端:

符合Spring框架的DAO 僅使用iBATIS SQL映射API的DAO。這些DAO可以生成兩種:通過構造函數或setter注入提供SqlMapClient。 符合iBATIS DAO框架的DAO(iBATIS的可選部分,現在不推薦使用此框架,我們建議您使用Spring框架)

MyBatis生成器設計為在迭代開發環境中運行良好,并且可以作為Ant任務或Maven插件包含在連續構建環境中。迭代運行MBG時需要注意的重要事項包括:

如果存在與新生成的XML文件同名的現有文件,MBG將自動合并XML文件。MBG不會覆蓋您對其生成的XML文件所做的任何自定義更改。您可以反復運行它,而不必擔心會丟失對XML的自定義更改。MBG將替換先前運行中生成的任何XML元素。

MBG不會合并Java文件,它可以覆蓋現有文件或使用不同的唯一名稱保存新生成的文件。如果對生成的Java文件進行更改并以迭代方式運行MBG,則必須手動合并更改。當作為Eclipse插件運行時 ,MBG可以自動合并Java文件。

二、MyBatis Generator使用

1、新建MBG的配置文件generatorConfig.xml文件

<?xml version='1.0' encoding='UTF-8'?><!DOCTYPE generatorConfiguration PUBLIC '-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN' 'http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd'><generatorConfiguration> <!--導入屬性配置--> <properties resource='generator.properties'></properties> <!--指定特定數據庫的jdbc驅動jar包的位置--> <!--<classPathEntry location='${jdbc.driverLocation}'/>--> <context targetRuntime='MyBatis3'> <!-- optional,旨在創建class時,對注釋進行控制,false生成注釋,true無注釋 --> <commentGenerator> <property name='suppressDate' value='false'/> <property name='suppressAllComments' value='false'/> </commentGenerator> <!--jdbc的數據庫連接 --> <jdbcConnection driverClass='${jdbc.driverClass}' connectionURL='${jdbc.connectionURL}' userId='${jdbc.userId}' password='${jdbc.password}'> </jdbcConnection> <!-- 默認false,把JDBC DECIMAL 和 NUMERIC 類型解析為 Integer, 為 true時把JDBC DECIMAL 和 NUMERIC 類型解析為java.math.BigDecimal --> <!-- 非必需,類型處理器,在數據庫類型和java類型之間的轉換控制--> <javaTypeResolver> <property name='forceBigDecimals' value='false'/> </javaTypeResolver> <!-- Model模型生成器,用來生成含有主鍵key的類,記錄類 以及查詢Example類 targetPackage 指定生成的model生成所在的包名 targetProject 指定在該項目下所在的路徑|指定生成到的工程名稱 --> <javaModelGenerator targetPackage='com.test.model' targetProject='.srcmainjava'> <!-- 是否允許子包,即targetPackage.schemaName.tableName --> <property name='enableSubPackages' value='false'/> <!-- 是否對model添加 構造函數 true添加,false不添加--> <property name='constructorBased' value='false'/> <!-- 是否對類CHAR類型的列的數據進行trim操作 --> <property name='trimStrings' value='true'/> <!-- 建立的Model對象是否 不可改變 即生成的Model對象不會有 setter方法,只有構造方法 --> <property name='immutable' value='false'/> </javaModelGenerator> <!--Mapper映射文件生成所在的目錄 為每一個數據庫的表生成對應的SqlMapper文件 --> <sqlMapGenerator targetPackage='com.test.mapper' targetProject='.srcmainjava'> <property name='enableSubPackages' value='false'/> </sqlMapGenerator> <!-- 客戶端代碼,生成易于使用的針對Model對象和XML配置文件 的代碼 type='ANNOTATEDMAPPER',生成Java Model 和基于注解的Mapper對象 type='MIXEDMAPPER',生成基于注解的Java Model 和相應的Mapper對象 type='XMLMAPPER',生成SQLMapper XML文件和獨立的Mapper接口 --> <javaClientGenerator targetPackage='com.test.mapper' targetProject='.srcmainjava' type='XMLMAPPER'> <property name='enableSubPackages' value='true'/> </javaClientGenerator> <!--需要映射的數據庫的表名--> <table tableName='t_userinfo' domainObjectName='UserInfo' enableCountByExample='false' enableUpdateByExample='false' enableDeleteByExample='false' enableSelectByExample='false' selectByExampleQueryId='false'> </table> </context></generatorConfiguration>

2、新建generator.properties文件

jdbc.driverLocation=C:mysql-connector-java-5.1.43.jarjdbc.driverClass=com.mysql.jdbc.Driverjdbc.connectionURL=jdbc:mysql://localhost:3306/mybatisjdbc.userId=rootjdbc.password=tiger

3、配置執行mybatis generator操作,這里有兩種方式

第1種方式:

如果使用maven項目就可以省去編寫Java啟動類,使用maven插件和配置文件pom.xml即可,插件啟動maven-generator,在pom.xml中添加maven-generator插件

<plugins> <!--myBatis逆向工程插件--> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> <configuration> <verbose>true</verbose> <overwrite>true</overwrite> <configurationFile>${project.basedir}/src/main/resources/generatorConfig.xml</configurationFile> </configuration> <dependencies> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.35</version> </dependency> </dependencies> </plugin></plugins>

點擊mybatis-generator:generate就能執行mybatis generator了

Mybatis Generator逆向工程的使用詳細教程

第2種方式:

1、如果不是maven項目添加該mybatis-generator-core-1.3.2.jar,編寫main方法指向mybatis逆向工程,我給依賴粘貼到下面了

<!-- https://mvnrepository.com/artifact/org.mybatis.generator/mybatis-generator-core --><dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.2</version></dependency>

2、修改generatorConfig.xml文件,放開注釋的該配置

<classPathEntry location='${jdbc.driverLocation}'/>

3、然后編寫測試類執行

/** * 如果不是maven項目可以這樣生成 */public class MybatisGeneratorTest { public static void main(String[] args) throws InterruptedException, SQLException, IOException, InvalidConfigurationException, XMLParserException { List<String> warnings = new ArrayList<String>(); //生成的java文件是否覆蓋 boolean overwrite = true; //指定逆向工程配置文件 //File configFile = new File('E:projectmybatis-generatorsrcmainresourcesgeneratorConfig.xml'); InputStream resourceAsStream = MybatisGeneratorTest.class.getClassLoader().getResourceAsStream('generatorConfig.xml'); ConfigurationParser cp = new ConfigurationParser(warnings); Configuration config = cp.parseConfiguration(resourceAsStream); DefaultShellCallback callback = new DefaultShellCallback(overwrite); MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config,callback, warnings); myBatisGenerator.generate(null); }}

介紹完這兩種方式,查看數據表:

Mybatis Generator逆向工程的使用詳細教程

查看生成的實體類:​

Mybatis Generator逆向工程的使用詳細教程

TIP:可以看出如果實體類想要遵循駝峰命名規范,數據庫表字段名設計需要用'_'來劃分

查看生成的文件信息:​

Mybatis Generator逆向工程的使用詳細教程

TIP1:必須在<plugin></plugin>標簽里添加數據庫驅動,在其他地方添加無效,如果不添加會報找不到驅動錯誤,如過不在該插件添加數據庫依賴的話可以使用 <classPathEntry location='${jdbc.driverLocation}'/> 來指定數據庫驅動位置。

TIP2:如果你在使用mybatis generator插件執行的時候報[ERROR] Failed to execute goal org.mybatis.generator:mybatis-generator-maven-plugin:1.3.2:generate (default-cli) on project mybatis-generator: <properties> resource generator.properties does not exist -> [Help 1]​

Mybatis Generator逆向工程的使用詳細教程

盡管你的 <properties resource='generator.properties'></properties>配置的沒有問題,但是還是找不到generator.properties,查看該配置,注釋掉​

Mybatis Generator逆向工程的使用詳細教程

該配置會改變generatorConfig.xml中讀取generator.properties文件的默認路徑

TIP3:Mybatis Generator反向工程默認不會覆蓋生成的*.java文件。也可以設置覆蓋生成的*.java文件,在反向工程插件mybatis-generator-maven-plugin添加該配置<overwrite>true</overwrite>則會覆蓋生成的*.java文件,如圖​

Mybatis Generator逆向工程的使用詳細教程

Mybatis Generator不會覆蓋你的mapper.xml文件,MBG會合并追加到mapper.xml和你自定義的存在一起,但是如果你修改MBG第一次默認生成的SQL(MBG生成的CRUD),MBG會重新把自己生成的CRUD恢復默認,說白了,MBG只會覆蓋他自己生成的SQL,不會覆蓋你自定義的,你自定義的不變。。。如圖,他不會動你的自定義SQL,只會覆蓋Mybatis反向工程自己生成的SQL,前提MBG自動生成SQL語句的注釋要存在。​

Mybatis Generator逆向工程的使用詳細教程

在最常見的用例中,MyBatis Generator(MBG)由XML配置文件驅動。配置文件告訴MBG

如何連接到數據庫 生成什么對象,以及如何生成它們 應使用哪些表生成對象

官方MBG配置文件詳解地址:http://mybatis.org/generator/configreference/xmlconfig.html

附帶一個MBG的中文配置文件詳解:https://www.jianshu.com/p/e09d2370b796

更多Mybatis逆向工程的使用參考:http://www.mybatis.org/generator/index.html

總結

到此這篇關于Mybatis Generator逆向工程的使用詳細教程的文章就介紹到這了,更多相關Mybatis Generator逆向工程內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美色图一区| 丝袜美腿亚洲一区| 日韩高清在线一区| 亚洲黄色影院| 99国产精品| 狠狠操综合网| 99成人在线| 伊人精品久久| 日韩在线观看中文字幕| 欧美在线亚洲| 国产午夜精品一区二区三区欧美| 欧美1级日本1级| 怡红院精品视频在线观看极品| 亚洲高清二区| 欧美日韩国产在线观看网站| 激情综合在线| 六月天综合网| 日韩精品导航| 国产精品密蕾丝视频下载| 欧美aaaaaa午夜精品| 国产成人精品一区二区三区在线| 精品国产黄a∨片高清在线| 97精品中文字幕| 国产精品毛片久久| av资源中文在线| 久久在线免费| 香蕉视频成人在线观看| 日精品一区二区三区| 国产精品sss在线观看av| 97人人精品| 99在线|亚洲一区二区| 日韩国产欧美在线播放| 美女久久精品| 激情欧美一区| 日韩在线观看一区二区三区| 久久影院资源站| 久久久久欧美精品| 蜜臀va亚洲va欧美va天堂| 国产精品一区二区精品视频观看| 久久麻豆视频| 免费毛片在线不卡| 欧美视频二区| 日韩国产综合| 免播放器亚洲一区| 久久亚洲精品中文字幕| 久久蜜桃av| 日韩精品免费一区二区夜夜嗨| 国产精品久久久久久久免费软件| 色网在线免费观看| 久久亚洲视频| 里番精品3d一二三区| 99久久久久国产精品| 亚洲精品少妇| 在线中文字幕播放| 久久尤物视频| 老牛国产精品一区的观看方式| 国产剧情在线观看一区| 欧美91精品| 欧美精品91| 国产亚洲一区在线| 麻豆精品蜜桃视频网站| 99国产精品久久久久久久| 国产精品久久| 国产精品视区| 欧美国产偷国产精品三区| 只有精品亚洲| 色网在线免费观看| 69堂免费精品视频在线播放| 99国产精品免费视频观看| 蜜臀久久99精品久久久久久9| 国产成人免费| 四虎在线精品| 久久九九国产| 国产日韩欧美中文在线| 欧美日韩国产高清| 国产aⅴ精品一区二区四区| 久久狠狠久久| 国产毛片一区| 日韩在线欧美| 欧美激情一区| 婷婷综合福利| 午夜在线视频观看日韩17c| yellow在线观看网址| 日本午夜免费一区二区| 午夜精品久久久久久久久久蜜桃| 国产毛片精品| 免费在线观看一区二区三区| 日韩精品午夜| 久久免费视频66| 日本不卡视频一二三区| 欧美女激情福利| 亚洲一级少妇| 欧美精品不卡| 91精品国产自产精品男人的天堂 | 亚久久调教视频| 九九综合在线| 久久婷婷av| 老色鬼精品视频在线观看播放| 日韩专区欧美专区| 偷拍欧美精品| 国产91精品对白在线播放| 另类小说一区二区三区| 日本成人手机在线| 日韩在线卡一卡二| 99热精品在线观看| 欧美a级片一区| 久久久噜噜噜| 午夜精品久久久久久久久久蜜桃| 精品国产一区二| 国产精品超碰| 国产精品毛片aⅴ一区二区三区| 亚洲欧美专区| 亚洲欧美不卡| 欧美不卡高清| 欧美影院三区| 久久精品亚洲欧美日韩精品中文字幕| 成人污污视频| 亚洲黄色中文字幕| 国产白浆在线免费观看| а√天堂8资源中文在线| 国产成人a视频高清在线观看| 捆绑调教美女网站视频一区| 国产乱子精品一区二区在线观看 | 日韩精品免费观看视频| 欧美国产视频| 日本中文字幕视频一区| 欧美成人基地| 日本免费一区二区三区四区| 色婷婷色综合| av综合电影网站| 中文字幕在线免费观看视频| 精品视频一区二区三区在线观看| 国产精品免费大片| 久久99国产精品视频| 精品欧美视频| 在线日韩中文| 视频一区二区中文字幕| 久久一区视频| 亚洲激情另类| 亚洲欧美日韩在线观看a三区| 日韩一区二区久久| 视频一区欧美日韩| 日韩中文字幕一区二区高清99| 日韩精品国产精品| 国产精品白浆| 国产不卡人人| 午夜日本精品| 一区二区高清| 日本在线成人| 你懂的亚洲视频| 国产成人精品一区二区三区视频| 欧美成人精品三级网站| 狠狠色综合网| 四虎成人精品一区二区免费网站| 国产亚洲一卡2卡3卡4卡新区| 亚洲中字黄色| 久久国产视频网| 荡女精品导航| 久久在线免费| 亚洲三级网站| 久久不卡国产精品一区二区| 国产v日韩v欧美v| 欧美1级日本1级| 日韩中文字幕一区二区高清99| 老司机免费视频一区二区三区| 国内在线观看一区二区三区 | 视频在线观看一区二区三区| 日本免费在线视频不卡一不卡二| 国产欧美日韩精品一区二区三区 | 日韩精品1区2区3区| 麻豆国产一区| 免费av一区二区三区四区| 日韩精品欧美大片| 高潮一区二区| 久久uomeier| 最新亚洲一区| 狠狠干成人综合网| 久久免费国产| 日韩精品电影一区亚洲| 高清在线一区| 亚洲精品精选| 日韩免费福利视频| 国产精品一区三区在线观看| 久久久久国产| 久久久久九九精品影院| 亚洲精品在线a| 婷婷激情综合| 欧美日韩视频网站| 久久精品凹凸全集| 日韩高清三区| 久久高清一区| 肉色欧美久久久久久久免费看| 麻豆国产一区| 激情婷婷久久| 综合五月婷婷| 国产精品九九| 国产亚洲精品v| 欧美一区成人| 成人日韩精品| 色狠狠一区二区三区|