关于使用mybatis时逆向工程()

首先需要在pom.xml中添加build插件与dependency依赖

dependency依赖如下:

  <!-- mybatis 下generator生成工具依赖包-->
        <dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-core</artifactId>

            <version>1.3.5</version>

        </dependency>
plugins插件
 <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.2</version>
                <executions>
                    <execution>
                        <id>Generate MyBatis Files</id>
                        <goals>
                            <goal>generate</goal>
                        </goals>
                        <phase>generate</phase>
                        <configuration>
                            <verbose>true</verbose>
                           <overwrite>true</overwrite>
                        </configuration>
                    </execution>
                </executions>
                <dependencies>
                <dependency>
                    <groupId>org.mybatis.generator</groupId>
                    <artifactId>mybatis-generator-core</artifactId>
                    <version>1.3.5</version>
                </dependency>
                <dependency>
                    <groupId>org.mybatis</groupId>
                    <artifactId>mybatis</artifactId>
                    <version>3.4.6</version>
                </dependency>
            </dependencies>
        </plugin>

然后创建generatorConfig.xml配置文件,配置要生成数据的信息(在网上看到有的同学喜欢吧数据库的连接信息放在db.properties文件中,凭个人喜好,当然我感觉这个放在db.properties中取出value更好一下)

配置文件信息为:

<?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>
    <!-- 指定连接数据库的JDBC驱动包所在位置,指定到你本机的完整路径(我是用的Oracle的数据库,第一次用这个做开发!!,mysql和他原理一样,找到驱动包即可) -->
    <classPathEntry location="D:\Users\Administrator\.m2\repository\com\oracle\ojdbc6\11.2.0.3\ojdbc6-11.2.0.3.jar"/>

    <!-- 配置table表信息内容体,targetRuntime指定采用MyBatis3的版本 -->
    <context id="tables" targetRuntime="MyBatis3">

        <!-- 抑制生成注释,由于生成的注释都是英文的,可以不让它生成 -->
        <commentGenerator>
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!--配置信息 驱动类,数据库连接信息,用户名,密码 -->
        <!-- 配置数据库连接信息 -->
        <jdbcConnection driverClass="oracle.jdbc.OracleDriver"
                        connectionURL="jdbc:oracle:thin:@192.168.103.88:1521:clamc"
                        userId="dev_team_3_test"
                        password="test">
        </jdbcConnection>

        <!-- 非必需,类型处理器,在数据库类型和java类型之间的转换控制-->
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>


        <!-- Model模型生成器,用来生成含有主键key的类,记录类 以及查询Example类
            targetPackage     指定生成的model生成所在的包名
            targetProject     指定在该项目下所在的路径
        -->
        <javaModelGenerator targetPackage="com.yss.flow.entity"
                            targetProject="src/main/java">

            <!-- 是否允许子包,即targetPackage.schemaName.tableName -->
            <property name="enableSubPackages" value="false"/>
            <!-- 是否对model添加 构造函数 -->
            <property name="constructorBased" value="false"/>
            <!-- 是否对类CHAR类型的列的数据进行trim操作 -->
            <property name="trimStrings" value="true"/>
            <!-- 建立的Model对象是否 不可改变  即生成的Model对象不会有 setter方法,只有构造方法 -->
            <property name="immutable" value="false"/>

        </javaModelGenerator>

        <!--Mapper映射文件生成所在的目录 为每一个数据库的表生成对应的SqlMap文件 -->
        <sqlMapGenerator targetPackage="mapper"
                         targetProject="src/main/resources">
            <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.yss.flow.mapper"
                             targetProject="src/main/java" type="XMLMAPPER">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>

        <!-- 对应的表与实体BO
        这里table是可以多实例生成的 
        -->
        <table tableName="T_XXXXXXXXXXXX" domainObjectName="T_XXXXXXXXXXXX"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>

        <table tableName="T_XXXXXXXXXXXX" domainObjectName="XXXXXXXXXXXX"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>
        <table tableName="T_XXXXXXXXXXXX" domainObjectName="T_XXXXXXXXXXXX"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>
        <table tableName="T_XXXXXXXXXXXX" domainObjectName="T_XXXXXXXXXXXX"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>
      
    </context>
</generatorConfiguration>

或者:

<?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     
 9         <!-- JavaBean 实现 序列化 接口 -->
10         <plugin type="org.mybatis.generator.plugins.SerializablePlugin">
11         </plugin>
12         <!-- genenat entity时,生成toString -->
13         <plugin type="org.mybatis.generator.plugins.ToStringPlugin" />
14         <!-- 自定义物理分页  可生成支持Mysql数据的limit  不支持Oracle -->
15         <plugin type="org.mybatis.generator.plugins.page.PaginationPlugin" />
16         <!-- 自定义查询指定字段  -->
17         <plugin type="org.mybatis.generator.plugins.field.FieldsPlugin" />
18         <!-- 开启支持内存分页   可生成 支持内存分布的方法及参数  
19         <plugin type="org.mybatis.generator.plugins.RowBoundsPlugin" />
20         -->
21         <!-- generate entity时,生成hashcode和equals方法
22         <plugin type="org.mybatis.generator.plugins.EqualsHashCodePlugin" />
23          -->
24         <!-- 此处是将Example改名为Criteria 当然 想改成什么都行~    -->      
25         <plugin type="org.mybatis.generator.plugins.RenameExampleClassPlugin">  
26             <property name="searchString" value="Example$" />
27             <!-- 替换后
28             <property name="replaceString" value="Criteria" />  
29              -->
30             <property name="replaceString" value="Query" />
31         </plugin>  
32         <!-- 此处是将UserMapper.xml改名为UserDao.xml 当然 想改成什么都行~ -->        
33         <plugin type="org.mybatis.generator.plugins.rename.RenameSqlMapperPlugin">  
34             <property name="searchString" value="Mapper" />
35             <property name="replaceString" value="Dao" />
36         </plugin>  
37          
38         <!-- 此处是将UserMapper改名为UserDao 接口 当然 想改成什么都行~  -->        
39         <plugin type="org.mybatis.generator.plugins.rename.RenameJavaMapperPlugin">  
40             <property name="searchString" value="Mapper$" />
41             <property name="replaceString" value="Dao" />
42         </plugin>  
43         
44  
45         
46         <commentGenerator type="org.mybatis.generator.plugins.comment.MyCommentGenerator">
47             <!-- 是否去除自动生成的注释 true:是 : false:否 
48             <property name="suppressAllComments" value="true" />
49             -->
50         </commentGenerator>
51         
52         <!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
53         <jdbcConnection driverClass="com.mysql.jdbc.Driver"
54             connectionURL="jdbc:mysql://localhost:3306/babasport" userId="root"
55             password="123456">
56         </jdbcConnection>
57         <!-- <jdbcConnection driverClass="oracle.jdbc.OracleDriver"
58             connectionURL="jdbc:oracle:thin:@127.0.0.1:1521:yycg" 
59             userId="yycg"
60             password="yycg">
61         </jdbcConnection> -->
62 
63         <!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 和 
64             NUMERIC 类型解析为java.math.BigDecimal -->
65         <javaTypeResolver>
66             <property name="forceBigDecimals" value="false" />
67         </javaTypeResolver>
68 
69 
70         <!-- targetProject:生成PO类的位置 -->
71         <javaModelGenerator targetPackage="cn.itcast.core.bean"
72             targetProject=".\src">
73             <!-- enableSubPackages:是否让schema作为包的后缀 -->
74             <property name="enableSubPackages" value="false" />
75             <!-- 从数据库返回的值被清理前后的空格 -->
76             <property name="trimStrings" value="true" />
77         </javaModelGenerator>
78 
79         <!-- targetProject:mapper映射文件生成的位置 -->
80         <sqlMapGenerator targetPackage="cn.itcast.core.dao" 
81             targetProject=".\src">
82             <!-- enableSubPackages:是否让schema作为包的后缀 -->
83             <property name="enableSubPackages" value="false" />
84         </sqlMapGenerator>
85         <!-- targetPackage:mapper接口生成的位置 -->
86         <javaClientGenerator type="XMLMAPPER"
87             targetPackage="cn.itcast.core.dao" 
88             targetProject=".\src">
89             <!-- enableSubPackages:是否让schema作为包的后缀 -->
90             <property name="enableSubPackages" value="true" />
91         </javaClientGenerator>
92         
93         <!-- 指定数据库表 -->
94         <!-- 用户模块表  -->
95         <table schema="" tableName="bbs_buyer" domainObjectName="user.Buyer"/>
96         
97         <!-- 商品模块表 -->
98         <table schema="" tableName="bbs_product" domainObjectName="product.Product">
99             <!-- 商品介绍 大字段映射 -->
100             <columnOverride column="description" javaType="String" jdbcType="VARCHAR" />
101             <!-- 包装清单 大字段映射 -->
102             <columnOverride column="package_list" javaType="String" jdbcType="VARCHAR" />
103             <!-- 商品图片 大字段映射 -->
104             <columnOverride column="img_url" javaType="String" jdbcType="VARCHAR" />
105         </table>
106         <table schema="" tableName="bbs_brand" domainObjectName="product.Brand"/>
107         <table schema="" tableName="bbs_Color" domainObjectName="product.Color"/>
108         <table schema="" tableName="bbs_sku" domainObjectName="product.Sku"/>
109         
110         <!-- 订单模块表 -->
111         <table schema="" tableName="bbs_order" domainObjectName="order.Order">
112             <!-- 支付方式 0:到付 1:在线 2:邮局 3:公司转帐 -->
113             <columnOverride column="payment_way" javaType="Integer"/>
114             <!-- 货到付款方式.1现金,2POS刷卡 -->
115             <columnOverride column="payment_cash" javaType="Integer" />
116             <!-- 送货时间 -->
117             <columnOverride column="delivery" javaType="Integer"/>
118             <!-- 支付状态 :0到付1待付款,2已付款,3待退款,4退款成功,5退款失败 -->
119             <columnOverride column="is_paiy" javaType="Integer"/>
120             <!-- 订单状态 0:提交订单 1:仓库配货 2:商品出库 3:等待收货 4:完成 5待退货 6已退货 -->
121             <columnOverride column="state" javaType="Integer"/>
122             <!-- 订单状态 默认Boolean -->
123             <columnOverride column="order_state" javaType="Integer"/>
124         </table>
125         <table schema="" tableName="bbs_detail" domainObjectName="order.Detail"/>
126         
127         <!-- 指定数据库所有表  
128         <table schema="" tableName="%"/>
129         -->
130         
131         <!-- 有些表的字段需要指定java类型
132          <table schema="" tableName="">
133             <columnOverride column="" javaType="" />
134         </table> -->
135     </context>
136 </generatorConfiguration>

有的表字段和属性名不一致的时候,这个我也想知道怎么吧数据库中表字段的某些参数名字符抑制生成,还有有时候我们使用到lombok不需要生成get,get与构造器。这时候也可以在上面的配置中配置。

 

配置完信息后就可以在Maven Project下执行了,如下:

 

双击就可以完成代码生成,(ps:我们在公司有时候是我们的实体类继承了公司的一套代码。这时候我们的代码中的生成的sql语句还有mapper下的接口可能会因为我们继承类中已经存在了该方法或者xml中存在sql语句报错,删除掉我们自己通过插件生成的sql与接口方法就好)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值