1、mybatis逆向工程概述
mybatis是目前很流行的持久層框架,很多企業都在采用。但是其復雜繁瑣的配置,重復性的實體類創建等等,消耗了程序員大量的精力,同時有些地方如果一個細小的疏忽,可能導致最終功能運行失敗。例如:在幾十個字段的表中,某一列的列名配置疏忽。
基於此,mybatis推出了一套jar包,可以依據我們設計好的數據庫表,自動生成pojo、mapper以及mapper.xml。有了逆向工程,便大大縮減了我們的開發時間。本章節將介紹借助idea的方式實現mybatis的逆向工程。
1.1 idea中mybatis逆向工程的使用
在idea中創建一個空的Javase項目,為該項目創建新的maven模塊mybatis_generator,添加如下坐標
<dependencies> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.7</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.5</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.7</version> <configuration> <verbose>true</verbose> <overwrite>true</overwrite> </configuration> </plugin> </plugins> </build>
1.2 編寫配置文件generatorConfig
<?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> <!-- classPathEntry:數據庫的 JDBC驅動的jar 包地址 --> <classPathEntry location="F:\\mysql-connector-java-5.1.32.jar" /> <context id="default" targetRuntime="MyBatis3"> <!-- 配置生成pojo的序列化的插件,mybatis支持很多插件,這些插件都在 org.mybatis.generator.plugins包下 --> <plugin type="org.mybatis.generator.plugins.SerializablePlugin" /> <commentGenerator> <!-- 是否去除自動生成的注釋 true:是 : false:否 --> <property name="suppressAllComments" value="false" /> </commentGenerator> <!--數據庫連接的信息:驅動類、連接地址、用戶名、密碼 --> <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://127.0.0.1:3306/數據庫名稱" userId="root" password="root"> </jdbcConnection> <javaTypeResolver> <property name="forceBigDecimals" value="false" /> </javaTypeResolver> <!-- targetProject:生成 POJO 類的位置,如果寫相對位置生成在該工程的相對位置,如果寫絕對位置則會在 --> <javaModelGenerator targetPackage="org.mybatis.pojo" targetProject="src/main/java"> <!-- 是否對model添加 構造函數 --> <property name="constructorBased" value="true"/> <!-- enableSubPackages:是否讓schema 作為包的后綴,是否允許子包,即targetPackage.schemaName.tableName --> <property name="enableSubPackages" value="false"/> <!-- 建立的Model對象是否 不可改變 即生成的Model對象不會有 setter方法,只有構造方法 --> <property name="immutable" value="false"/> <!-- 是否對類CHAR類型的列的數據進行trim操作,從數據庫返回的值被清理前后的空格 --> <property name="trimStrings" value="true"/> </javaModelGenerator> <!-- 生成 XML文件 --> <sqlMapGenerator targetPackage="org.mybatis.mapper" targetProject="./src/main/resources"> <property name="enableSubPackages" value="false" /> </sqlMapGenerator> <!--生成接口--> <javaClientGenerator type="XMLMAPPER" targetPackage="org.mybatis.mapper" targetProject="./src/main/java"> <property name="enableSubPackages" value="false" /> </javaClientGenerator> <!-- 指定數據庫表 --> <table tableName="co_export" domainObjectName="Export" mapperName="ExportDao" enableCountByExample="false" enableDeleteByExample="false" enableSelectByExample="false" enableUpdateByExample="false"/>
</context>
</generatorConfiguration>
1.3 執行插件
配置完成后,按照下圖雙擊執行即可。
也可以參考閱讀:https://www.cnblogs.com/ysocean/p/7360409.html
拓展(很重要):逆向工程可以在Dao層生成selectByExample()等類似於xxxByExample格式的方法(Factory和FactoryExample是mybatis逆向生成的類)舉例
//創建Example對象 FactoryExample example = new FactoryExample(); //對此對象提供了多種條件查詢的方法 FactoryExample.Criteria criteria = example.createCriteria();
//設置條件 criteria.andFactoryNameLike("%廠%");//舉例 List<Factory> list = factoryDao.selectByExample(example);
Eclipse通過main方法進行生成
package com.aoker; import java.io.File; import java.util.ArrayList; /*以來的坐標 <dependencies> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.7</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.6</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.5</version> </dependency> </dependencies> */ /*jdbc.properties jdbc.path=D:\\ruanjian\\apache-maven-3.5.4-bin\\repository\\mysql\\mysql-connector-java\\5.1.6 jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/saas-export-ee88 jdbc.username=root jdbc.password=root */ /* mybatis-generator-config.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"></properties> <!--指定特定數據庫的jdbc驅動jar包的位置--> <classPathEntry location="${jdbc.path}"/> <context id="context" targetRuntime="MyBatis3"> <!-- 是否去除自動生成的注釋 true:是 : false:否 --> <commentGenerator> <property name="suppressAllComments" value="false"/> <property name="suppressDate" value="true"/> </commentGenerator> <!--數據庫連接的信息:驅動類、連接地址、用戶名、密碼 --> <jdbcConnection driverClass="${jdbc.driver}" connectionURL="${jdbc.url}" userId="${jdbc.username}" password="${jdbc.password}"/> <!-- 默認false,把JDBC DECIMAL 和 NUMERIC 類型解析為 Integer,為 true時把JDBC DECIMAL 和 NUMERIC 類型解析為java.math.BigDecimal --> <javaTypeResolver> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <!--指定包名生成實體類 以及生成的地址 (可以自定義地址,如果路徑不存在會自動創建) --> <javaModelGenerator targetPackage="com.itheima.domain.cargo" targetProject="I:\ee88\mybatis_demo\mybatis_generator\src\main\java"> <!-- enableSubPackages:是否讓schema作為包的后綴 --> <property name="enableSubPackages" value="false"/> <!-- 從數據庫返回的值被清理前后的空格 --> <property name="trimStrings" value="true"/> </javaModelGenerator> <!--Mapper映射文件生成所在的目錄 為每一個數據庫的表生成對應的mapper文件 --> <sqlMapGenerator targetPackage="com.itheima.dao.cargo" targetProject="I:\ee88\mybatis_demo\mybatis_generator\src\main\resources"> <!-- enableSubPackages:是否讓schema作為包的后綴 --> <property name="enableSubPackages" value="false"/> </sqlMapGenerator> <!-- 客戶端代碼,生成易於使用的針對Model對象和XML配置文件 的代碼 type="ANNOTATEDMAPPER",生成Java Model 和基於注解的Mapper對象 type="MIXEDMAPPER",生成基於注解的Java Model 和相應的Mapper對象 type="XMLMAPPER",生成SQLMap XML文件和獨立的Mapper接口 --> <javaClientGenerator targetPackage="com.itheima.dao.cargo" targetProject="I:\ee88\mybatis_demo\mybatis_generator\src\main\java" type="XMLMAPPER"> <!-- enableSubPackages:是否讓schema作為包的后綴 --> <property name="enableSubPackages" value="false"/> </javaClientGenerator> <!-- 指定數據庫表 <table schema="saas-export" tableName="co_export" domainObjectName="Export" mapperName="ExportDao" enableCountByExample="false" enableDeleteByExample="false" enableSelectByExample="false" enableUpdateByExample="false"/> <table schema="saas-export" tableName="co_export_product" domainObjectName="ExportProduct" mapperName="ExportProductDao" enableCountByExample="false" enableDeleteByExample="false" enableSelectByExample="false" enableUpdateByExample="false"/> <table schema="saas-export" tableName="co_ext_eproduct" domainObjectName="ExtEproduct" mapperName="ExtEproductDao" enableCountByExample="false" enableDeleteByExample="false" enableSelectByExample="false" enableUpdateByExample="false"/>--> <!--enableCountByExample 開啟統計查詢帶條件--> <!--enableDeleteByExample 開啟刪除帶條件--> <!--enableSelectByExample 開啟查詢帶條件--> <!--enableUpdateByExample 開啟更新帶條件--> <table schema="saas-export-ee88" tableName="co_factory" domainObjectName="Factory" mapperName="FactoryDao" enableCountByExample="false" enableDeleteByExample="false" enableSelectByExample="true" enableUpdateByExample="false"/> </context> </generatorConfiguration> */ import org.mybatis.generator.api.MyBatisGenerator; import org.mybatis.generator.config.Configuration; import org.mybatis.generator.config.xml.ConfigurationParser; import org.mybatis.generator.internal.DefaultShellCallback; import java.io.InputStream; import java.util.ArrayList; import java.util.List; /** * */ public class GeneratorSqlMap { public void generator() throws Exception { List<String> warnings = new ArrayList<String>(); boolean overwrite = true; //指定 逆向工程配置文件 InputStream in = GeneratorSqlMapTest.class.getClassLoader().getResourceAsStream("mybatis-generator-config.xml"); ConfigurationParser cp = new ConfigurationParser(warnings); Configuration config = cp.parseConfiguration(in); DefaultShellCallback callback = new DefaultShellCallback(overwrite); MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings); myBatisGenerator.generate(null); in.close(); } public static void main(String[] args) throws Exception { try { GeneratorSqlMapTest generatorSqlmap = new GeneratorSqlMapTest(); generatorSqlmap.generator(); } catch (Exception e) { e.printStackTrace(); } } }