简单来说,Mybatis逆向工程可以根据数据库的表来逆向生成相关java代码和sql语句,如mapper.java,mapper.xml。虽然mapper接口及其配置文件我们完全可以自己写,不过当表数量很多,关联复杂时,用MyBatis Generator逆向工程就十分方便了。当然了,我们也可以根据业务逻辑修改其生成的mapper。 将mybatis-generator-core相关jar包导入项目,在maven仓库中搜索mybatis generator,复制代码到pom.xml。 新建配置文件mbg.xml,配置数据库连接,指定生成文件及位置,指定待生成的数据库的表等。 配置完后,官网上逆向生成的方法有很多,如命令行,eclipse插件等,这里介绍用java代码调用。 Run As->Java Application什么是逆向工程?
导入jar包
不了解Maven的小伙伴,可以点这里。
或者直接下载并导入jar包,github下载地址。<!-- https://mvnrepository.com/artifact/org.mybatis.generator/mybatis-generator-core --> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.5</version> </dependency>
配置文件
<?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> <!--这里用的是MyBatis3Simple即简单的增删改查--> <!--一般使用MyBatis3--> <context id="DB2Tables" targetRuntime="MyBatis3Simple"> <!-- 逆向生成清除注释 --> <commentGenerator> <property name="suppressAllComments" value="true" /> </commentGenerator> <!-- 数据库连接配置 --> <jdbcConnection driverClass="com.mysql.cj.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/experiment9?serverTimezone=UTC" userId="root" password="数据库密码"> <property name="nullCatalogMeansCurrent" value="true"/> </jdbcConnection> <javaTypeResolver > <property name="forceBigDecimals" value="false" /> </javaTypeResolver> <!-- 指定javaBean逆生成位置 --> <javaModelGenerator targetPackage="cn.csdn.bean" targetProject=".srcmainjava"> <property name="enableSubPackages" value="true" /> <property name="trimStrings" value="true" /> </javaModelGenerator> <!-- 指定sql映射文件生成的位置 --> <sqlMapGenerator targetPackage="mapper" targetProject=".srcmainresources"> <property name="enableSubPackages" value="true" /> </sqlMapGenerator> <!-- 指定dao接口生成的位置,mapper接口 --> <javaClientGenerator type="XMLMAPPER" targetPackage="cn.csdn.dao" targetProject=".srcmainjava"> <property name="enableSubPackages" value="true" /> </javaClientGenerator> <!-- 指定每个表的生成策略 --> <table tableName="message" domainObjectName="Message"></table> <table tableName="product" domainObjectName="Product"></table> <table tableName="revert" domainObjectName="Revert"></table> <table tableName="user" domainObjectName="User"></table> </context> </generatorConfiguration>
生成代码
新建MBGTest.javapackage cn.csdn.test; 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; public class MBGTest { public static void main(String[] args) throws Exception { List<String> warnings = new ArrayList<String>(); boolean overwrite = true; File configFile = new File("mbg.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); System.out.println("finish"); } }
最后控制台打印finish,刷新目录,就有生成的文件了。
你的将会是我最大的动力
本网页所有视频内容由 imoviebox边看边下-网页视频下载, iurlBox网页地址收藏管理器 下载并得到。
ImovieBox网页视频下载器 下载地址: ImovieBox网页视频下载器-最新版本下载
本文章由: imapbox邮箱云存储,邮箱网盘,ImageBox 图片批量下载器,网页图片批量下载专家,网页图片批量下载器,获取到文章图片,imoviebox网页视频批量下载器,下载视频内容,为您提供.
阅读和此文章类似的: 全球云计算