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


本文摘自PHP中文网,作者php是最好的语言,侵删。

MyBatis的逆向工程

一:什么是逆行工程。

1

2

3

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

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

相关文章:

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

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

相关视频:

MySQLi面向过程极速入门

以上就是MyBatis的逆向工程的解析及简单教程(附代码)的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql出现错误编码1114怎么办

常用mysql优化sql语句查询方法汇总

详解mysql实时同步到oracle解决方案

如何验证是否安装mysql

mysql初次不能登录解决方法

mysql中的数据类型和schema优化

mysql行级锁实现原理是什么

详解如何通过ssh通道来访问mysql

mysql主从复制原理是什么

mysql查询怎么优化?mysql查询优化的方法介绍

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

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

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...