MyBatis的逆向工程详解

2025-05-29 0 37

一:什么是逆行工程。

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

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

二:简单教程

maven的pom.xml中添加插件

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53
<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

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56
<?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类即可生成

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。

原文链接:https://segmentfault.com/a/1190000015853535

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 MyBatis的逆向工程详解 https://www.kuaiidc.com/111416.html

相关文章

发表评论
暂无评论