MyBatis代码生成器

àì夳堔傛蜴生んèń 2022-02-23 09:52 525阅读 0赞

使用MyBatis-generator生成代码

我们在学习MyBatis的时候,总是要做很多基础的CRUD,这些代码都是比较重复的。为了解决这个问题,我们可以使用MyBatis的代码生成器。
1.创建一个idea的maven项目,并以pom方式导入相应jar包

  1. <!--mysql的驱动包-->
  2. <dependency>
  3. <groupId>mysql</groupId>
  4. <artifactId>mysql-connector-java</artifactId>
  5. <version>5.1.38</version>
  6. </dependency>
  7. <!--mybatis核心包-->
  8. <dependency>
  9. <groupId>org.mybatis</groupId>
  10. <artifactId>mybatis</artifactId>
  11. <version>3.2.1</version>
  12. </dependency>

2.导入代码生成器(pom.xml)

  1. <build>
  2. <plugins>
  3. <!--代码生成器插件-->
  4. <plugin>
  5. <groupId>org.mybatis.generator</groupId>
  6. <artifactId>mybatis-generator-maven-plugin</artifactId>
  7. <version>1.3.2</version>
  8. <configuration>
  9. <!--自定义代码生成器的路径-->
  10. <!--<configurationFile>yourLocation/mybatis-generator-config.xml</configurationFile>-->
  11. <verbose>true</verbose>
  12. <overwrite>true</overwrite>
  13. </configuration>
  14. </plugin>
  15. </plugins>
  16. </build>

3.创建好相应的层级关系(domain,mapper和存放映射文件的文件夹)
在这里插入图片描述
4.然后创建generatorConfig.xml文件
注意:代码生成器会自动在根目录中找寻名为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. <!--
  8. classPathEntry:可以配置多个,也不配置
  9. 数据库驱动:这里找到相应的驱动jar包就可以了(注:不同数据库的jar不一样)
  10. location:里面的是路径(也可以直接写绝对路径 -> 如:E:\mybatis\mysql-connector-java-5.1.26-bin.jar)
  11. -->
  12. <classPathEntry location="E:\opensources\mysql-connector-java-5.1.26-bin.jar(自己的数据库驱动包的路径)"/>
  13. <!--
  14. context:用于生成一组对象的环境(至少配置1个,可以配置多个)
  15. id:表达唯一的名称
  16. targetRuntime:用于指定生成的代码的运行环境(MyBatis3/MyBatis3Simple)
  17. MyBatis3:默认值
  18. MyBatis3Simple:不会生成与Example(案例)相关的方法
  19. -->
  20. <context id="DB2Tables" targetRuntime="MyBatis3Simple" >
  21. <!--
  22. 用于配置如果生成注释信息(最多可以配置一下)
  23. suppressAllComments:阻止生成注释 ,默认为false
  24. suppressDate:阻止生成的注释 时间戳,默认为false
  25. addRemarkComments:注释是否添加数据库表的备注信息,默认为false
  26. -->
  27. <commentGenerator>
  28. <property name="suppressDate" value="true"/>
  29. <property name="suppressAllComments" value="true"/>
  30. </commentGenerator>
  31. <!--
  32. 这个应该比较清楚,配置连接数据库的基本信息
  33. -->
  34. <jdbcConnection driverClass="com.mysql.jdbc.Driver"
  35. connectionURL="jdbc:mysql:///myproject"
  36. userId="root"
  37. password="123456">
  38. </jdbcConnection>
  39. <!--
  40. 用于指定JDBC类型和Java类型如何转换,最多可以配置一个
  41. forceBigDecimals:控制是否强制将DECIMAL和NUMERIC类型的JDBC字段转换成Java类型的 BigDecimal
  42. 默认为false,一般不需要配置
  43. -->
  44. <javaTypeResolver>
  45. <property name="forceBigDecimals" value="false"/>
  46. </javaTypeResolver>
  47. <!--
  48. javaModelGenerator:用来控制生成的实体类
  49. targetPackage:生成Model类存放位置(包名)
  50. targetProject:指定目标项目路径(根目录)
  51. 对应的子属性:
  52. trimStrings:判断是否对数据库查询结果进行trim操作(默认false)
  53. -->
  54. <javaModelGenerator targetPackage="my.domain" targetProject="src/main/java(生成实体类存放的文件夹路径)">
  55. <property name="trimStrings" value="true"/>
  56. </javaModelGenerator>
  57. <!--
  58. sqlMapGenerator:生成映射文件存放位置(Mapper.xml文件)
  59. targetPackage:生成SQL映射文件(XML文件)在哪个包中
  60. targetProject:指定目标项目路径(根目录)
  61. -->
  62. <sqlMapGenerator targetPackage="my.mapper" targetProject="src/main/resources(存放相应映射文件路径)">
  63. </sqlMapGenerator>
  64. <!--
  65. javaClientGenerator:Java客户端生成器(生成Dao/Mapper的接口)
  66. 该 标签可选(最多配置一个),如果不配置,就不会生成Mapper接口
  67. type:选择客户端代码生成器
  68. MyBatis3
  69. ANNOTATEDMAPPER:基于注解的Mapper接口,不会有对应的XML映射文件
  70. MIXEDMAPPER:XML和注解混合形式
  71. XMLMAPPER:所有方法都在XML中(接口调用依赖XML)
  72. MyBatis3Simple
  73. ANNOTATEDMAPPER:基于注解的Mapper接口,不会有对应的XML映射文件
  74. XMLMAPPER:所有方法都在XML中(接口调用依赖XML)
  75. targetPackage:生成Mapper接口存放的包名
  76. targetProject:指定目标项目路径
  77. -->
  78. <javaClientGenerator type="XMLMAPPER" targetPackage="my.mapper" targetProject="src/main/java(存放生成相应接口的路径)">
  79. <property name="enableSubPackages" value="true"/>
  80. </javaClientGenerator>
  81. <!--
  82. table:生成对应表及类名
  83. tableName:对应表名(注:%代表所有)
  84. domainObjectName:对应的类名
  85. generatedKey:主键自增的id字段(针对当前 数据库配置MySQL)
  86. -->
  87. <table tableName="user" domainObjectName="User">
  88. <generatedKey column="id" sqlStatement="MySql" />
  89. </table>
  90. <table tableName="main" domainObjectName="Main">
  91. <generatedKey column="id" sqlStatement="MySql" />
  92. </table>
  93. </context>
  94. </generatorConfiguration>

4.完成上述步骤后运行代码生成器
在这里插入图片描述
5.结果如下
在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,525人围观)

还没有评论,来说两句吧...

相关阅读