当前位置:Gxlcms > mysql > MyBatis的逆向工程的解析及简单教程(附代码)

MyBatis的逆向工程的解析及简单教程(附代码)

时间:2021-07-01 10:21:17 帮助过:34人阅读

MyBatis的逆向工程

一:什么是逆行工程。

  1. MyBatis是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
  2. 当数据库表比较多的时候,重复的创建pojo对象和简单的数据库表的(CRUD)操作的mapper,效率低,官方给出了使用mybatis Generator用来根据数据库表逆向生成pojo和mapper文件,极大的方便开发。

二:简单教程

  • maven的pom.xml中添加插件

  1. <packaging>jar</packaging>
  2. <dependencies>
  3. <!-- 添加对mybatis的依赖 -->
  4. <dependency>
  5. <groupId>org.mybatis</groupId>
  6. <artifactId>mybatis</artifactId>
  7. </dependency>
  8. <dependency>
  9. <groupId>org.mybatis</groupId>
  10. <artifactId>mybatis-spring</artifactId>
  11. </dependency>
  12. <dependency>
  13. <groupId>com.github.miemiedev</groupId>
  14. <artifactId>mybatis-paginator</artifactId>
  15. </dependency>
  16. <dependency>
  17. <groupId>com.github.pagehelper</groupId>
  18. <artifactId>pagehelper</artifactId>
  19. </dependency>
  20. <!-- MySql -->
  21. <dependency>
  22. <groupId>mysql</groupId>
  23. <artifactId>mysql-connector-java</artifactId>
  24. </dependency>
  25. <!-- 连接池 -->
  26. <dependency>
  27. <groupId>com.alibaba</groupId>
  28. <artifactId>druid</artifactId>
  29. </dependency>
  30. <dependency>
  31. <groupId>org.mybatis.generator</groupId>
  32. <artifactId>mybatis-generator-core</artifactId>
  33. <version>1.3.6</version>
  34. </dependency>
  35. </dependencies>
  36. <build>
  37. <plugins>
  38. <!-- mybatis逆向工程 -->
  39. <plugin>
  40. <groupId>org.mybatis.generator</groupId>
  41. <artifactId>mybatis-generator-maven-plugin</artifactId>
  42. <version>1.3.7</version>
  43. <configuration>
  44. <!--配置文件的位置-->
  45. <configurationFile>src/main/resources/generatorConfig.xml</configurationFile>
  46. <verbose>true</verbose>
  47. <overwrite>true</overwrite>
  48. </configuration>
  49. </plugin>
  50. </plugins>
  51. </build>
  • 创建配置文件 generatorConfig.xml

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE generatorConfiguration PUBLIC
  3. "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
  4. "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd" >
  5. <generatorConfiguration>
  6. <!--引入数据库配置文件方便修改-->
  7. <properties resource="jdbc.properties"/>
  8. <!--数据库驱动文件 需要修改 TODO-->
  9. <classPathEntry
  10. location="/Volumes/Tool/JAVA_Tool/maven/Maven_Repository/mysql/mysql-connector-java/5.1.32/mysql-connector-java-5.1.32.jar"/>
  11. <context id="context" targetRuntime="MyBatis3Simple">
  12. <commentGenerator>
  13. <!-- 是否去除自动生成的注释,true:是;false:否 -->
  14. <property name="suppressAllComments" value="true"/>
  15. <property name="suppressDate" value="false"/>
  16. </commentGenerator>
  17. <!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
  18. <jdbcConnection driverClass="${jdbc.driverClassName}"
  19. connectionURL="${jdbc.url}"
  20. userId="${jdbc.username}"
  21. password="${jdbc.password}"/>
  22. <!--默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,-->
  23. <!--为 true时把JDBC DECIMAL 和 NUMERIC 类型解析为java.math.BigDecimal -->
  24. <!-- 非必需,类型处理器,在数据库类型和java类型之间的转换控制-->
  25. <javaTypeResolver>
  26. <property name="forceBigDecimals" value="false"/>
  27. </javaTypeResolver>
  28. <!--生成PO类的位置 配置生成的实体包-->
  29. <!--targetPackage:生成的实体包位置,默认存放在src目录下-->
  30. <!--targetProject:相对路径 路径拼接结果 src/main/java/one/domain -->
  31. <javaModelGenerator targetPackage="one.domain" targetProject="src/main/java">
  32. <!-- enableSubPackages:是否让schema作为包的后缀 -->
  33. <property name="enableSubPackages" value="false"/>
  34. <!-- 从数据库返回的值被清理前后的空格 -->
  35. <property name="trimStrings" value="true"/>
  36. </javaModelGenerator>
  37. <!-- 实体包对应映射文件位置及名称,默认存放在src目录下 同上 -->
  38. <sqlMapGenerator targetPackage="MapperXml" targetProject="src/main/resources">
  39. <!-- enableSubPackages:是否让schema作为包的后缀 -->
  40. <property name="enableSubPackages" value="false"/>
  41. </sqlMapGenerator>
  42. <!--targetPackage:mapper接口生成的位置-->
  43. <javaClientGenerator targetPackage="one.mapper" type="XMLMAPPER" targetProject="src/main/java">
  44. <!-- enableSubPackages:是否让schema作为包的后缀 -->
  45. <property name="enableSubPackages" value="false"/>
  46. </javaClientGenerator>
  47. <!--配置表-->
  48. <!--schema:不用填写-->
  49. <!--tableName: 表名 TODO-->
  50. <!--enableCountByExample、enableSelectByExample、enableDeleteByExample、enableUpdateByExample、selectByExampleQueryId:-->
  51. <!--去除自动生成的注释例子-->
  52. <table tableName="tb_user" enableCountByExample="false" enableDeleteByExample="false"
  53. enableSelectByExample="false" enableUpdateByExample="false"/>
  54. </context>
  55. </generatorConfiguration>
  • 运行Generator类即可生成

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

相关文章:

MyBatis入门(七)---逆向工程

Spring+SpringMVC+MyBatis深入学习及搭建——MyBatis逆向工程

相关视频:

MySQLi面向过程极速入门

以上就是MyBatis的逆向工程的解析及简单教程(附代码)的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行