【MyBatis框架】mybatis逆向工程自动生成代码

本文介绍MyBatis逆向工程的基本概念及使用方法,包括下载逆向工程工具、配置生成代码参数、执行生成程序等步骤,并展示了如何使用生成的代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

逆向工程

1.什么是逆向工程

mybaits需要程序员自己编写sql语句,mybatis官方提供逆向工程 可以针对单表自动生成mybatis执行所需要的代码(mapper.java,mapper.xml、po..)

企业实际开发中,常用的逆向工程方式:
由于数据库的表生成java代码。

2.下载逆向工程
mybatis-generator-core-1.3.2-bundle.zip

3.使用方法(会用)

3.1运行逆向工程 
官方文档中提供的运行逆向工程的几种方法
Running MyBatis Generator

MyBatis Generator (MBG) can be run in the following ways:

(1)From the command prompt with an XML configuration
(2)As an Ant task with an XML configuration
(3)As a Maven Plugin
(4)From another Java program with an XML configuration
(5)From another Java program with a Java based configuration
(6)还可以通过eclipse的插件生成代码

建议使用java程序方式(From another Java program with an XML configuration),不依赖开发工具。

下面创建一个生成逆向文件的工程,将自动生成的文件再拷贝到原工程中去(这么做是为了放止直接在源文件中生成会覆盖掉同名文件)
导入的jar包和工程结构截图如下:

如图



3.2生成代码配置文件
generatorConfig.xml:
  1. <?xml version=“1.0” encoding=“UTF-8”?>  
  2. <!DOCTYPE generatorConfiguration  
  3.   PUBLIC ”-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN”  
  4.   “http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd”>  
  5.   
  6. <generatorConfiguration>  
  7.     <context id=“testTables” targetRuntime=“MyBatis3”>  
  8.         <commentGenerator>  
  9.             <!– 是否去除自动生成的注释 true:是 : false:否 –>  
  10.             <property name=“suppressAllComments” value=“true” />  
  11.         </commentGenerator>  
  12.         <!–数据库连接的信息:驱动类、连接地址、用户名、密码 –>  
  13.         <jdbcConnection driverClass=“com.mysql.jdbc.Driver”  
  14.             connectionURL=“jdbc:mysql://localhost:3306/mybatis” userId=“root”  
  15.             password=“1234”>  
  16.         </jdbcConnection>  
  17.         <!– <jdbcConnection driverClass=“oracle.jdbc.OracleDriver”  
  18.             connectionURL=“jdbc:oracle:thin:@127.0.0.1:1521:yycg”   
  19.             userId=“yycg”  
  20.             password=“yycg”>  
  21.         </jdbcConnection> –>  
  22.   
  23.         <!– 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 和   
  24.             NUMERIC 类型解析为java.math.BigDecimal –>  
  25.         <javaTypeResolver>  
  26.             <property name=“forceBigDecimals” value=“false” />  
  27.         </javaTypeResolver>  
  28.   
  29.         <!– targetProject:生成PO类的位置 –>  
  30.         <javaModelGenerator targetPackage=“cn.edu.hpu.ssm.po”  
  31.             targetProject=“.\src”>  
  32.             <!– enableSubPackages:是否让schema作为包的后缀 –>  
  33.             <property name=“enableSubPackages” value=“false” />  
  34.             <!– 从数据库返回的值被清理前后的空格 –>  
  35.             <property name=“trimStrings” value=“true” />  
  36.         </javaModelGenerator>  
  37.         <!– targetProject:mapper映射文件生成的位置 –>  
  38.         <sqlMapGenerator targetPackage=“cn.edu.hpu.ssm.mapper”   
  39.             targetProject=“.\src”>  
  40.             <!– enableSubPackages:是否让schema作为包的后缀 –>  
  41.             <property name=“enableSubPackages” value=“false” />  
  42.         </sqlMapGenerator>  
  43.         <!– targetPackage:mapper接口生成的位置 –>  
  44.         <javaClientGenerator type=“XMLMAPPER”  
  45.             targetPackage=“cn.edu.hpu.ssm.mapper”   
  46.             targetProject=“.\src”>  
  47.             <!– enableSubPackages:是否让schema作为包的后缀 –>  
  48.             <property name=“enableSubPackages” value=“false” />  
  49.         </javaClientGenerator>  
  50.         <!– 指定数据库表 –>  
  51.         <table tableName=“items”></table>  
  52.         <table tableName=“orders”></table>  
  53.         <table tableName=“orderdetail”></table>  
  54.         <table tableName=“user”></table>  
  55.         <!– <table schema=“” tableName=“sys_user”></table>  
  56.         <table schema=“” tableName=“sys_role”></table>  
  57.         <table schema=“” tableName=“sys_permission”></table>  
  58.         <table schema=“” tableName=“sys_user_role”></table>  
  59.         <table schema=“” tableName=“sys_role_permission”></table> –>  
  60.           
  61.         <!– 有些表的字段需要指定java类型  
  62.          <table schema=“” tableName=“”>  
  63.             <columnOverride column=“” javaType=“” />  
  64.         </table> –>  
  65.     </context>  
  66. </generatorConfiguration>  
<?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://localhost:3306/mybatis" userId="root"
            password="1234">
        </jdbcConnection>
        <!-- <jdbcConnection driverClass="oracle.jdbc.OracleDriver"
            connectionURL="jdbc:oracle:thin:@127.0.0.1:1521:yycg" 
            userId="yycg"
            password="yycg">
        </jdbcConnection> -->

        <!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 和 
            NUMERIC 类型解析为java.math.BigDecimal -->
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>

        <!-- targetProject:生成PO类的位置 -->
        <javaModelGenerator targetPackage="cn.edu.hpu.ssm.po"
            targetProject=".\src">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="false" />
            <!-- 从数据库返回的值被清理前后的空格 -->
            <property name="trimStrings" value="true" />
        </javaModelGenerator>
        <!-- targetProject:mapper映射文件生成的位置 -->
        <sqlMapGenerator targetPackage="cn.edu.hpu.ssm.mapper" 
            targetProject=".\src">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="false" />
        </sqlMapGenerator>
        <!-- targetPackage:mapper接口生成的位置 -->
        <javaClientGenerator type="XMLMAPPER"
            targetPackage="cn.edu.hpu.ssm.mapper" 
            targetProject=".\src">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="false" />
        </javaClientGenerator>
        <!-- 指定数据库表 -->
        <table tableName="items"></table>
        <table tableName="orders"></table>
        <table tableName="orderdetail"></table>
        <table tableName="user"></table>
        <!-- <table schema="" tableName="sys_user"></table>
        <table schema="" tableName="sys_role"></table>
        <table schema="" tableName="sys_permission"></table>
        <table schema="" tableName="sys_user_role"></table>
        <table schema="" tableName="sys_role_permission"></table> -->

        <!-- 有些表的字段需要指定java类型
         <table schema="" tableName="">
            <columnOverride column="" javaType="" />
        </table> -->
    </context>
</generatorConfiguration>

3.3执行生成程序
GeneratorSqlmap.java: 
  1. import java.io.File;  
  2. import java.util.ArrayList;  
  3. import java.util.List;  
  4.   
  5. import org.mybatis.generator.api.MyBatisGenerator;  
  6. import org.mybatis.generator.config.Configuration;  
  7. import org.mybatis.generator.config.xml.ConfigurationParser;  
  8. import org.mybatis.generator.internal.DefaultShellCallback;  
  9.   
  10.   
  11. public class GeneratorSqlmap {  
  12.   
  13.   
  14.     public void generator() throws Exception{  
  15.   
  16.   
  17.         List<String> warnings = new ArrayList<String>();  
  18.         boolean overwrite = true;  
  19.         //加载配置文件  
  20.         File configFile = new File(“generatorConfig.xml”);   
  21.         ConfigurationParser cp = new ConfigurationParser(warnings);  
  22.         Configuration config = cp.parseConfiguration(configFile);  
  23.         DefaultShellCallback callback = new DefaultShellCallback(overwrite);  
  24.         MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config,  
  25.                 callback, warnings);  
  26.         myBatisGenerator.generate(null);  
  27.   
  28.   
  29.     }   
  30.     public static void main(String[] args) throws Exception {  
  31.         try {  
  32.             GeneratorSqlmap generatorSqlmap = new GeneratorSqlmap();  
  33.             generatorSqlmap.generator();  
  34.         } catch (Exception e) {  
  35.             e.printStackTrace();  
  36.         }  
  37.           
  38.     }  
  39. }  
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{


        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);


    } 
    public static void main(String[] args) throws Exception {
        try {
            GeneratorSqlmap generatorSqlmap = new GeneratorSqlmap();
            generatorSqlmap.generator();
        } catch (Exception e) {
            e.printStackTrace();
        }

    }
}


生成后的代码:

如图



3.4使用生成的代码

需要将生成工程中所生成的代码拷贝到自己的工程中。我们这里吧ItemsMapper.java和ItemsMapper.xml、Items、ItemsExample类拷入我们的原工程。

测试ItemsMapper中的方法
  1. package cn.edu.hpu.ssm.test;  
  2.   
  3. import static org.junit.Assert.fail;  
  4.   
  5. import java.util.Date;  
  6. import java.util.List;  
  7.   
  8.   
  9. import org.junit.Before;  
  10. import org.junit.Test;  
  11. import org.springframework.context.ApplicationContext;  
  12. import org.springframework.context.support.ClassPathXmlApplicationContext;  
  13.   
  14.   
  15. import cn.edu.hpu.ssm.mapper.ItemsMapper;  
  16. import cn.edu.hpu.ssm.po.Items;  
  17. import cn.edu.hpu.ssm.po.ItemsExample;  
  18.   
  19.   
  20. public class ItemsMapperTest {  
  21.   
  22.   
  23.     private ApplicationContext applicationContext;  
  24.       
  25.     private ItemsMapper itemsMapper;  
  26.       
  27.     //注解Before是在执行本类所有测试方法之前先调用这个方法  
  28.     @Before  
  29.     public void setup() throws Exception{  
  30.         applicationContext=new ClassPathXmlApplicationContext(“classpath:spring/applicationContext.xml”);  
  31.         itemsMapper=(ItemsMapper)applicationContext.getBean(”itemsMapper”);  
  32.     }  
  33.       
  34.     //根据主键删除  
  35.     @Test  
  36.     public void testDeleteByPrimaryKey() {  
  37.         fail(”Not yet implemented”);  
  38.     }  
  39.   
  40.   
  41.     //插入  
  42.     @Test  
  43.     public void testInsert() {  
  44.         Items items=new Items();  
  45.         items.setName(”iPhone-5S”);  
  46.         items.setPrice(3999f);  
  47.         items.setDetail(”正品行货”);  
  48.         items.setPic(”sdasd.jpg”);  
  49.         items.setCreatetime(new Date());  
  50.         itemsMapper.insert(items);  
  51.     }  
  52.   
  53.   
  54.     //自定义条件来查询  
  55.     @Test  
  56.     public void testSelectByExample() {  
  57.         ItemsExample itemsExample=new ItemsExample();  
  58.         //通过Criteria构造查询条件  
  59.         ItemsExample.Criteria criteria=itemsExample.createCriteria();  
  60.         criteria.andNameEqualTo(”电视机”);  
  61.         //可能返回多条记录  
  62.         List<Items> list=itemsMapper.selectByExample(itemsExample);  
  63.         for (int i = 0; i < list.size(); i++) {  
  64.             Items it=list.get(i);  
  65.             System.out.println(it.getId()+”:”+it.getName());  
  66.         }  
  67.     }  
  68.   
  69.   
  70.     //根据主键来查询  
  71.     @Test  
  72.     public void testSelectByPrimaryKey() {  
  73.         Items items=itemsMapper.selectByPrimaryKey(1);  
  74.         System.out.println(items.getName());  
  75.     }  
  76.   
  77.   
  78.     //更新数据  
  79.     @Test  
  80.     public void testUpdateByPrimaryKey() {  
  81.         //对所有字段进行更新,需要先查询出来再更新  
  82.         Items items = itemsMapper.selectByPrimaryKey(1);      
  83.         items.setName(”iPhone”);      
  84.         itemsMapper.updateByPrimaryKey(items);  
  85.           
  86.         //如果传入字段不空为才更新,在批量更新中使用此方法,不需要先查询再更新  
  87.         //itemsMapper.updateByPrimaryKeySelective(record);  
  88.     }  
  89.   
  90.   
  91. }  
package cn.edu.hpu.ssm.test;

import static org.junit.Assert.fail;

import java.util.Date;
import java.util.List;


import org.junit.Before;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;


import cn.edu.hpu.ssm.mapper.ItemsMapper;
import cn.edu.hpu.ssm.po.Items;
import cn.edu.hpu.ssm.po.ItemsExample;


public class ItemsMapperTest {


    private ApplicationContext applicationContext;

    private ItemsMapper itemsMapper;

    //注解Before是在执行本类所有测试方法之前先调用这个方法
    @Before
    public void setup() throws Exception{
        applicationContext=new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml");
        itemsMapper=(ItemsMapper)applicationContext.getBean("itemsMapper");
    }

    //根据主键删除
    @Test
    public void testDeleteByPrimaryKey() {
        fail("Not yet implemented");
    }


    //插入
    @Test
    public void testInsert() {
        Items items=new Items();
        items.setName("iPhone-5S");
        items.setPrice(3999f);
        items.setDetail("正品行货");
        items.setPic("sdasd.jpg");
        items.setCreatetime(new Date());
        itemsMapper.insert(items);
    }


    //自定义条件来查询
    @Test
    public void testSelectByExample() {
        ItemsExample itemsExample=new ItemsExample();
        //通过Criteria构造查询条件
        ItemsExample.Criteria criteria=itemsExample.createCriteria();
        criteria.andNameEqualTo("电视机");
        //可能返回多条记录
        List<Items> list=itemsMapper.selectByExample(itemsExample);
        for (int i = 0; i < list.size(); i++) {
            Items it=list.get(i);
            System.out.println(it.getId()+":"+it.getName());
        }
    }


    //根据主键来查询
    @Test
    public void testSelectByPrimaryKey() {
        Items items=itemsMapper.selectByPrimaryKey(1);
        System.out.println(items.getName());
    }


    //更新数据
    @Test
    public void testUpdateByPrimaryKey() {
        //对所有字段进行更新,需要先查询出来再更新
        Items items = itemsMapper.selectByPrimaryKey(1);    
        items.setName("iPhone");    
        itemsMapper.updateByPrimaryKey(items);

        //如果传入字段不空为才更新,在批量更新中使用此方法,不需要先查询再更新
        //itemsMapper.updateByPrimaryKeySelective(record);
    }


}

逆向工程的创建和使用就讲解到这里

转载请注明出处:http://blog.youkuaiyun.com/acmman/article/details/46906871

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值