【MyBatis框架】MyBatis的逆向工程生成代码,如何生成逆向工程
2017-12-15 12:39
811 查看
1:逆向工程是什么。
介绍:mybatis的一个主要的特点就是需要程序员自己编写mybatis.xml的sql语句,如果表太多的话,自己写就难免会很麻烦,所以mybatis官方提供了一个逆向工程,可以针对单表自动生成mybatis执行所需要的代码(包括mapper.xml、mapper.java、po..)。一般在开发中,常用的逆向工程方式是通过数据库的表生成代码。
2:怎么使用逆向工程。
2-1新建一个工程(重要)新建一个java工程,下载逆向工程后导入到新建的java工程里面。
逆向工程代码(下载地址)—->:[点我下载]
导入后结构如下:
2-1-1 此步骤注意事项:逆向工程结构说明.
①:是要执行的java代码,执行它即可生成我们需要的代码;
②:是执行过程中新建的包,这个包都可以在4的配置文件中指定,最好是跟我们自己项目的包名一致,后面就可以直接拷贝了,就不需要修改包名了;
③:就是jar包咯;
④:是配置文件。
2-2生成代码的配置文件(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> <context id="testTables" targetRuntime="MyBatis3"> <commentGenerator> <!-- 是否去除自动生成的注释 true:是 : false:否 --> <property name="suppressAllComments" value="true" /> </commentGenerator> <!--数据库连接的信息:驱动类、连接地址、用户名、密码 --> <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://192.168.1.6:3306/jock2017" userId="root" password="jockpw"> </jdbcConnection> <!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 和 NUMERIC 类型解析为java.math.BigDecimal --> <javaTypeResolver> <property name="forceBigDecimals" value="false" /> </javaTypeResolver> <!-- targetProject:生成PO类的位置 --> <javaModelGenerator targetPackage="com.ssm.jock.po" targetProject=".\src"> <!-- enableSubPackages:是否让schema作为包的后缀 --> <property name="enableSubPackages" value="false" /> <!-- 从数据库返回的值被清理前后的空格 --> <property name="trimStrings" value="true" /> </javaModelGenerator> <!-- targetProject:mapper映射文件生成的位置 --> <sqlMapGenerator targetPackage="com.ssm.jock.mapper" targetProject=".\src"> <!-- enableSubPackages:是否让schema作为包的后缀 --> <property name="enableSubPackages" value="false" /> </sqlMapGenerator> <!-- targetPackage:mapper接口生成的位置 --> <javaClientGenerator type="XMLMAPPER" targetPackage="com.ssm.jock.mapper" targetProject=".\src"> <!-- enableSubPackages:是否让schema作为包的后缀 --> <property name="enableSubPackages" value="false" /> </javaClientGenerator> <!--指定数据库表--> <table tableName="g_info"></table> <table tableName="g_label"></table> </context> </generatorConfiguration>
2-2-1 此步骤注意事项:从上面的配置文件中可以看出,配置文件主要要做的几件事是
①:连接数据库,这是必须的,要不然怎么根据数据库的表生成代码呢?
②:指定要生成代码的位置,要生成的代码包括po类, mapper.xml和mapper.java
③:指定数据库中想要生成哪些表
3:测试逆向工程。
3-1 执行生成逆向代码程序(GeneratorSqlmap.java)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 GeneratorSqlmap { public void generator() throws Exception{ System.out.println("开始..."); List<String> warnings = new ArrayList<String>(); boolean overwrite = true; //指定 逆向工程配置文件 File configFile = new File("generatorConfig.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("完成!"); } public static void main(String[] args) throws Exception { try { GeneratorSqlmap generatorSqlmap = new GeneratorSqlmap(); generatorSqlmap.generator(); } catch (Exception e) { e.printStackTrace(); } } }
3-1-1此步骤注意事项:
①:指定 逆向工程配置文件。指定才能生成到所需的数据库表
3-1-2 页面截图:
3-2-1 此步骤生成后解释说明 :
①:【com.ssm.jock.mapper】 里面的Mapper和XML文件就是逆向生成的接口和mybatis配置
②:【cpm.ssm.jock.po】 里面的就是实体类和Example类是给用户自定义sql是用的。
3-2-2 详细解释每个类 :(拿GInfo这个表来说)
①:数据库表结构
②:GinfoMapper.java【提供大部分增删改查的方法,不需要自己写接口,已经生成好了】
③:GinfoMapper.xml【自动生成mybatis对应的数据库表的xml文件,不用自己写了】
④:GInfo.java【自动生成数据库表的实体类文件】
⑤:GInfoExample.java【自动生成数据库表的实体拓展类文件】
相关文章推荐
- 【MyBatis框架】mybatis逆向工程自动生成代码
- MyBatis框架的学习(七)——MyBatis逆向工程自动生成代码
- MyBatis框架之mybatis逆向工程自动生成代码
- 【MyBatis框架】mybatis逆向工程自动生成代码
- (转)MyBatis框架的学习(七)——MyBatis逆向工程自动生成代码
- MyBatis框架之mybatis逆向工程自动生成代码
- 【MyBatis框架】mybatis逆向工程自动生成代码
- MyBatis框架的学习(七)——MyBatis逆向工程自动生成代码
- 【MyBatis框架】mybatis逆向工程自动生成代码
- MyBatis的逆向工程生成代码
- 【MyBatis学习15】MyBatis的逆向工程生成代码
- 【MyBatis学习15】MyBatis的逆向工程生成代码
- 在IDEA中使用MyBatis Generator逆向工程生成代码
- Mybatis 逆向工程 自动生成代码
- 在IDEA中使用MyBatis Generator逆向工程生成代码
- mybatis-generator逆向生成工程代码
- 在IDEA中使用MyBatis Generator逆向工程生成代码
- 2018_03_14 mybatis逆向工程生成代码
- mybatis逆向工程生成代码
- 在IDEA中使用MyBatis Generator逆向工程生成代码