這篇文章主要介紹了MyBatis中逆向工程的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著(zhù)大家一起了解一下。
MyBatis是一款優(yōu)秀的持久層框架,它支持定制化SQL、存儲過(guò)程以及高級映射。MyBatis 避免了幾乎所有的 JDBC 代碼和手動(dòng)設置參數以及獲取結果集。MyBatis 可以使用簡(jiǎn)單的 XML 或注解來(lái)配置和映射原生信息,將接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java對象)映射成數據庫中的記錄。 當數據庫表比較多的時(shí)候,重復的創(chuàng )建pojo對象和簡(jiǎn)單的數據庫表的(CRUD)操作的mapper,效率低,官方給出了使用mybatis Generator用來(lái)根據數據庫表逆向生成pojo和mapper文件,極大的方便開(kāi)發(fā)。
maven的pom.xml中添加插件
<packaging>jar</packaging> <dependencies> <!-- 添加對mybatis的依賴(lài) --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> </dependency> <dependency> <groupId>com.github.miemiedev</groupId> <artifactId>mybatis-paginator</artifactId> </dependency> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> </dependency> <!-- --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <!-- 連接池 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> </dependency> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.6</version> </dependency> </dependencies> <build> <plugins> <!-- mybatis逆向工程 --> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.7</version> <configuration> <!--配置文件的位置--> <configurationFile>src/main/resources/generatorConfig.xml</configurationFile> <verbose>true</verbose> <overwrite>true</overwrite> </configuration> </plugin> </plugins> </build>
創(chuàng )建配置文件 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="jdbc.properties"/> <!--數據庫驅動(dòng)文件 需要修改 TODO--> <classPathEntry location="/Volumes/Tool/JAVA_Tool/maven/Maven_Repository/mysql/mysql-connector-java/5.1.32/mysql-connector-java-5.1.32.jar"/> <context id="context" targetRuntime="MyBatis3Simple"> <commentGenerator> <!-- 是否去除自動(dòng)生成的注釋?zhuān)瑃rue:是;false:否 --> <property name="suppressAllComments" value="true"/> <property name="suppressDate" value="false"/> </commentGenerator> <!--數據庫連接的信息:驅動(dòng)類(lèi)、連接地址、用戶(hù)名、密碼 --> <jdbcConnection driverClass="${jdbc.driverClassName}" connectionURL="${jdbc.url}" userId="${jdbc.username}" password="${jdbc.password}"/> <!--默認false,把JDBC DECIMAL 和 NUMERIC 類(lèi)型解析為 Integer,--> <!--為 true時(shí)把JDBC DECIMAL 和 NUMERIC 類(lèi)型解析為java.math.BigDecimal --> <!-- 非必需,類(lèi)型處理器,在數據庫類(lèi)型和java類(lèi)型之間的轉換控制--> <javaTypeResolver> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <!--生成PO類(lèi)的位置 配置生成的實(shí)體包--> <!--targetPackage:生成的實(shí)體包位置,默認存放在src目錄下--> <!--targetProject:相對路徑 路徑拼接結果 src/main/java/one/domain --> <javaModelGenerator targetPackage="one.domain" targetProject="src/main/java"> <!-- enableSubPackages:是否讓schema作為包的后綴 --> <property name="enableSubPackages" value="false"/> <!-- 從數據庫返回的值被清理前后的空格 --> <property name="trimStrings" value="true"/> </javaModelGenerator> <!-- 實(shí)體包對應映射文件位置及名稱(chēng),默認存放在src目錄下 同上 --> <sqlMapGenerator targetPackage="MapperXml" targetProject="src/main/resources"> <!-- enableSubPackages:是否讓schema作為包的后綴 --> <property name="enableSubPackages" value="false"/> </sqlMapGenerator> <!--targetPackage:mapper接口生成的位置--> <javaClientGenerator targetPackage="one.mapper" type="XMLMAPPER" targetProject="src/main/java"> <!-- enableSubPackages:是否讓schema作為包的后綴 --> <property name="enableSubPackages" value="false"/> </javaClientGenerator> <!--配置表--> <!--schema:不用填寫(xiě)--> <!--tableName: 表名 TODO--> <!--enableCountByExample、enableSelectByExample、enableDeleteByExample、enableUpdateByExample、selectByExampleQueryId:--> <!--去除自動(dòng)生成的注釋例子--> <table tableName="tb_user" enableCountByExample="false" enableDeleteByExample="false" enableSelectByExample="false" enableUpdateByExample="false"/> </context> </generatorConfiguration>
運行Generator類(lèi)即可生成
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站