MyBatis的逆向工程详解

作者:source 时间:2022-12-03 11:06:10 

一:什么是逆行工程。

MyBatis是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

当数据库表比较多的时候,重复的创建pojo对象和简单的数据库表的(CRUD)操作的mapper,效率低,官方给出了使用mybatis Generator用来根据数据库表逆向生成pojo和mapper文件,极大的方便开发。

二:简单教程

maven的pom.xml中添加插件


<packaging>jar</packaging>
<dependencies>

<!-- 添加对mybatis的依赖 -->
 <dependency>
  <groupId>org.mybatis</groupId>
  <artifactId>mybatis</artifactId>
 </dependency>
 <dependency>
  <groupId>org.mybatis</groupId>
  <artifactId>mybatis-spring</artifactId>
 </dependency>
 <dependency>
  <groupId>com.github.miemiedev</groupId>
  <artifactId>mybatis-paginator</artifactId>
 </dependency>
 <dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper</artifactId>
 </dependency>
 <!-- MySql -->
 <dependency>
  <groupId>mysql</groupId>
  <artifactId>mysql-connector-java</artifactId>
 </dependency>
 <!-- 连接池 -->
 <dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>druid</artifactId>
 </dependency>

<dependency>
  <groupId>org.mybatis.generator</groupId>
  <artifactId>mybatis-generator-core</artifactId>
  <version>1.3.6</version>
 </dependency>
</dependencies>
<build>
 <plugins>
  <!-- mybatis逆向工程 -->
  <plugin>
   <groupId>org.mybatis.generator</groupId>
   <artifactId>mybatis-generator-maven-plugin</artifactId>
   <version>1.3.7</version>
   <configuration>
    <!--配置文件的位置-->
    <configurationFile>src/main/resources/generatorConfig.xml</configurationFile>
    <verbose>true</verbose>
    <overwrite>true</overwrite>
   </configuration>
  </plugin>
 </plugins>
</build>

创建配置文件 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>
<!--引入数据库配置文件方便修改-->
<properties resource="jdbc.properties"/>
<!--数据库驱动文件 需要修改 TODO-->
<classPathEntry
  location="/Volumes/Tool/JAVA_Tool/maven/Maven_Repository/mysql/mysql-connector-java/5.1.32/mysql-connector-java-5.1.32.jar"/>

<context id="context" targetRuntime="MyBatis3Simple">
 <commentGenerator>
  <!-- 是否去除自动生成的注释,true:是;false:否 -->
  <property name="suppressAllComments" value="true"/>
  <property name="suppressDate" value="false"/>
 </commentGenerator>
 <!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
 <jdbcConnection driverClass="${jdbc.driverClassName}"
     connectionURL="${jdbc.url}"
     userId="${jdbc.username}"
     password="${jdbc.password}"/>
 <!--默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,-->
 <!--为 true时把JDBC DECIMAL 和 NUMERIC 类型解析为java.math.BigDecimal -->
 <!-- 非必需,类型处理器,在数据库类型和java类型之间的转换控制-->
 <javaTypeResolver>
  <property name="forceBigDecimals" value="false"/>
 </javaTypeResolver>
 <!--生成PO类的位置 配置生成的实体包-->
 <!--targetPackage:生成的实体包位置,默认存放在src目录下-->
 <!--targetProject:相对路径 路径拼接结果 src/main/java/one/domain -->
 <javaModelGenerator targetPackage="one.domain" targetProject="src/main/java">
  <!-- enableSubPackages:是否让schema作为包的后缀 -->
  <property name="enableSubPackages" value="false"/>
  <!-- 从数据库返回的值被清理前后的空格 -->
  <property name="trimStrings" value="true"/>
 </javaModelGenerator>
 <!-- 实体包对应映射文件位置及名称,默认存放在src目录下 同上 -->
 <sqlMapGenerator targetPackage="MapperXml" targetProject="src/main/resources">
  <!-- enableSubPackages:是否让schema作为包的后缀 -->
  <property name="enableSubPackages" value="false"/>
 </sqlMapGenerator>
 <!--targetPackage:mapper接口生成的位置-->
 <javaClientGenerator targetPackage="one.mapper" type="XMLMAPPER" targetProject="src/main/java">
  <!-- enableSubPackages:是否让schema作为包的后缀 -->
  <property name="enableSubPackages" value="false"/>
 </javaClientGenerator>
 <!--配置表-->
 <!--schema:不用填写-->
 <!--tableName: 表名 TODO-->
 <!--enableCountByExample、enableSelectByExample、enableDeleteByExample、enableUpdateByExample、selectByExampleQueryId:-->
 <!--去除自动生成的注释例子-->
 <table tableName="tb_user" enableCountByExample="false" enableDeleteByExample="false"
   enableSelectByExample="false" enableUpdateByExample="false"/>
</context>
</generatorConfiguration>

运行Generator类即可生成

我已经做好项目了 下载即可运行

来源:https://segmentfault.com/a/1190000015853535

标签:MyBatis,逆向工程
0
投稿

猜你喜欢

  • Java中super和this关键字详解

    2023-03-18 15:49:08
  • 详解java中的阻塞队列

    2021-11-26 12:24:44
  • 简单了解Java编程中线程的创建与守护线程

    2023-11-25 06:59:52
  • Android设置项目为系统APP方法

    2022-11-16 08:55:02
  • Ubuntu中为Android实现Application Frameworks层增加硬件访问服务

    2021-05-28 14:20:02
  • Kotlin编程循环控制示例详解

    2022-06-02 11:53:54
  • Java List转换成String数组几种实现方式详解

    2023-11-10 07:19:41
  • C# 使用HttpClient模拟请求的案例

    2023-10-16 18:20:14
  • SpringSecurity+Redis认证过程小结

    2021-07-21 11:38:11
  • Spring Security实现两周内自动登录"记住我"功能

    2021-12-15 17:59:22
  • c#自定义Attribute获取接口实现示例代码

    2022-09-02 05:05:26
  • C#使用foreach循环遍历数组完整实例

    2021-12-27 15:10:33
  • springmvc 参数绑定总结

    2023-11-16 21:30:44
  • Mybatis基于xml配置实现单表的增删改查功能

    2021-09-29 11:21:48
  • 微信公众号 网页授权登录及code been used解决详解

    2023-02-06 18:49:00
  • Android时间对话框TimePickerDialog详解

    2022-08-23 05:50:06
  • Android从网络中获得一张图片并显示在屏幕上的实例详解

    2023-11-03 01:17:43
  • C#内置队列类Queue用法实例

    2023-07-18 14:12:05
  • 浅谈@Aspect@Order各个通知的执行顺序

    2021-10-24 19:00:38
  • Android自动播放Banner图片轮播效果

    2022-09-06 05:55:42
  • asp之家 软件编程 m.aspxhome.com