Mybatis generator如何自動生成代碼
開發(fā)項目的時候,表很多,是不可能一點點的自己去寫xml ,dao文件的,這里就需要用到代碼的自動生成工具了。
第一步:導(dǎo)入jar包,當(dāng)然,這之前,基本環(huán)境,像mybatis,數(shù)據(jù)庫之類的都得搭建好。
<dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.2</version> </dependency>
第二步:創(chuàng)建啟動的 xml配置文件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> <context targetRuntime='MyBatis3'> <commentGenerator> <!-- 是否去除自動生成的注釋 true:是 : false:否 --> <property name='suppressAllComments' value='true' /> </commentGenerator> <!--數(shù)據(jù)庫連接的信息:驅(qū)動類、連接地址、用戶名、密碼 --><jdbcConnection driverClass='com.mysql.jdbc.Driver' connectionURL='***' userId='***' password='***'/> <!-- 默認false,把JDBC DECIMAL 和 NUMERIC 類型解析為 Integer,為 true時把JDBC DECIMAL 和 NUMERIC 類型解析為java.math.BigDecimal --> <javaTypeResolver> <property name='forceBigDecimals' value='false' /> </javaTypeResolver> <!-- targetProject:生成PO類的位置 --> <javaModelGenerator targetPackage='com.sun.mybatis.dto' targetProject='.srctestjava'> <!-- enableSubPackages:是否讓schema作為包的后綴 --> <property name='enableSubPackages' value='false' /> <!-- 從數(shù)據(jù)庫返回的值被清理前后的空格 --> <property name='trimStrings' value='true' /> </javaModelGenerator> <!-- targetProject:mapper映射文件生成的位置 --> <sqlMapGenerator targetPackage='com.sun.mybatis.mapper' targetProject='.srctestjava'> <!-- enableSubPackages:是否讓schema作為包的后綴 --> <property name='enableSubPackages' value='false' /> </sqlMapGenerator> <!-- targetPackage:mapper接口生成的位置 --> <javaClientGenerator type='XMLMAPPER' targetPackage='com.sun.mybatis.dao' targetProject='.srctestjava'> <!-- enableSubPackages:是否讓schema作為包的后綴 --> <property name='enableSubPackages' value='false' /> </javaClientGenerator> <!-- 指定數(shù)據(jù)庫表 --> <table schema='' tableName='b_staff' ></table> <table schema='' tableName='b_contents' ></table> <!-- <table tableName='CTAS_FEE_BASE' domainObjectName='FeeBase'enableCountByExample='false' enableUpdateByExample='false'enableDeleteByExample='false' enableSelectByExample='false'selectByExampleQueryId='false'> --> <!-- 有些表的字段需要指定java類型 <table schema='' tableName=''> <columnOverride column='' javaType='' /> </table> --> </context></generatorConfiguration>
第三步,寫個主方法,去運行就行了
import java.io.File;import java.util.ArrayList;import java.util.List;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;/** * @author szy * @version 創(chuàng)建時間:2018-6-4 下午9:26:54 * */public class MybatisGenerator { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub try { MybatisGenerator generatorSqlmap = new MybatisGenerator(); generatorSqlmap.generator(); } catch (Exception e) { e.printStackTrace(); } } public void generator() throws Exception{ List<String> warnings = new ArrayList<String>(); boolean overwrite = true; //指定 逆向工程配置文件 File configFile = new File('E:/java-workspace/myblog/src/main/resources/mybatis-generator-config.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); }}
完成,刷新下就能看到代碼都出來了。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Access數(shù)據(jù)庫安全的幾個問題2. Sql server數(shù)據(jù)庫開發(fā)常用匯總3. ORACLE中如何實現(xiàn)ASCII字符串和16進制串互相轉(zhuǎn)換4. 關(guān)于Oracle數(shù)據(jù)庫熱備份腳本深入剖析5. Oracle的PDB數(shù)據(jù)庫創(chuàng)建DIRECTORY時遇到ORA-65254問題及解決方法6. mysql-bin.000001文件的來源及處理方法7. MySQL 的啟動選項和系統(tǒng)變量實例詳解8. 如何遠程調(diào)用ACCESS數(shù)據(jù)庫9. MySQL雙主(主主)架構(gòu)配置方案10. oracle數(shù)據(jù)庫id自增及生成uuid問題
