NO.08 MyBatis创建逆向工程

这篇具有很好参考价值的文章主要介绍了NO.08 MyBatis创建逆向工程。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1、前言

2、添加依赖和插件

 3、创建MyBatis的核心配置文件

 4、创建逆向工程的配置文件

 5、执行MBG插件的generate目标


1、前言

工程的创建有正向工程和逆向工程之分。正向工程:先创建Java实体类,由框架负责根据实体类生成数据库表,如Hibernate是支持正向工程的。 逆向工程:先创建数据库表,由框架负责根据数据库表,反向生成如下资源: Java实体类 Mapper接口 Mapper映射文件,如MyBatis支持逆向工程。

本篇以t_minister表、t_dutie表为例,表结构可查看NO.06 自定义映射resultMap_qq_46053741的博客-CSDN博客

2、添加依赖和插件

 在pom.xm文件中添加一下依赖:mysql-connector-java、mybatis-generator-core、junit、log4j,在pom.xml文件中添加build标签,在build标签中添加plugins子标签,plugins标签中主要是添加构建过程中用到的插件;在plugins标签中添加子标签plugin子标签,主要添加创建做成中用到的具体插件,插件主要有以下几个:mybatis-generator-maven-plugin、mybatis-generator-core、mysql-connector-java。

下面是pom.xml配置文件的详细内容

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.review.mybatis</groupId>
  <artifactId>review_mbg</artifactId>
  <version>1.0-SNAPSHOT</version>
  <name>Archetype - review_mbg</name>
  <url>http://maven.apache.org</url>
  <packaging>jar</packaging>

  <dependencies>
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.37</version>
    </dependency>
    <dependency>
      <groupId>org.mybatis.generator</groupId>
      <artifactId>mybatis-generator-core</artifactId>
      <version>1.3.0</version>
    </dependency>
    <dependency>
      <groupId>log4j</groupId>
      <artifactId>log4j</artifactId>
      <version>1.2.12</version>
    </dependency>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.13.2</version>
      <scope>test</scope>
    </dependency>
  </dependencies>
  <!-- 控制Maven在构建过程中相关配置 -->
  <build>
    <!-- 构建过程中用到的插件 -->
    <plugins>
      <!-- 具体插件,逆向工程的操作是以构建过程中插件形式出现的 -->
      <plugin>
        <groupId>org.mybatis.generator</groupId>
        <artifactId>mybatis-generator-maven-plugin</artifactId>
        <version>1.3.0</version>
        <!-- 插件的依赖 -->
        <dependencies>
          <!-- 逆向工程的核心依赖 -->
          <dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-core</artifactId>
            <version>1.3.0</version>
          </dependency>
          <!-- MySQL驱动 -->
          <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.37</version>
          </dependency>
        </dependencies>
      </plugin>
    </plugins>
  </build>
</project>

 3、创建MyBatis的核心配置文件

在配置核心配置文件之前需要创建jdbc.properties文件,配置数据库连接信息。

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/review
jdbc.username=root
jdbc.password=123456789

配置文件详细内容如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

    <!--
        MyBatis核心配置文件中的标签必须要按照指定的顺序配置:
        properties?,settings?,typeAliases?,typeHandlers?,
        objectFactory?,objectWrapperFactory?,reflectorFactory?,
        plugins?,environments?,databaseIdProvider?,mappers?
    -->

    <!--引入properties文件,此后就可以在当前文件中使用的方式访问value-->
    <properties resource="jdbc.properties"/>

    <!--
        typeAliases:设置类型别名,即为某个具体的类型设置一个别名
        在MyBatis的范围中,就可以使用别名表示一个具体的类型
    -->
    <typeAliases>
        <!--
            type:设置需要起别名的类型
            alias:设置某个类型的别名
        -->
        <!--        <typeAlias type="com.review.mybatis.Pojo.User" alias="abc"></typeAlias>-->
        <!--        若不设置alias,当前的类型拥有默认的别名,即类名且不区分大小写-->
        <!--        <typeAlias type="com.review.mybatis.pojo.User"></typeAlias>-->
        <!--通过包设置类型别名,指定包下所有的类型将全部拥有默认的别名,即类名且不区分大小写-->
        <package name="com.review.mybatis.pojo"/>
    </typeAliases>


    <!--    配置连接数据库的环境-->
<!--
    environments:配置连接数据库的环境
    属性:
    default:设置默认使用的环境的id
-->
    <environments default="development">
        <environment id="development">
<!--
                transactionManager:设置事务管理器
                属性:
                type:设置事务管理的方式
                type="JDBC|MANAGED"
                JDBC:表示使用JDBC中原生的事务管理方式
                MANAGED:被管理,例如Spring
-->
            <transactionManager type="JDBC"/>
<!--
                dataSource:设置数据源
                属性:
                type:设置数据源的类型
                type="POOLED|UNPOOLED|JNDI"
                POOLED:表示使用数据库连接池
                UNPOOLED:表示不使用数据库连接池
                JNDI:表示使用上下文中的数据源
-->
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>

        <environment id="test">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/review"/>
                <property name="username" value="root"/>
                <property name="password" value="123456789"/>
            </dataSource>
        </environment>
    </environments>
<!--    引入mybatis的映射文件-->
<!--
    以包的方式引入映射文件,但是必须满足两个条件:
    1、mapper接口和映射文件所在的包必须一致
    2、mapper接口的名字和映射文件的名字必须一致
-->
    <mappers>
<!--        <mapper resource="mappers/MinisterMapper.xml"/>-->
<!--
        以包的方式引入映射文件,但是必须满足两个条件:
        1、mapper接口和映射文件所在的包必须一致
        2、mapper接口的名字和映射文件的名字必须一致
-->
        <package name="com.review.mybatis.mapper"/>
    </mappers>
</configuration>

 配置文件中typeAliases标签中的package子标签表示以包设置类型别名,指定包下所有的类型将全部拥有默认的别名,即类名且不区分大小写,name属性的value值是实体类包的路径。

mapper标签中的package子标签表示以包的方式引入映射文件,但是必须满足两个条件:1、mapper接口和映射文件所在的包必须一致;2、mapper接口的名字和映射文件的名字必须一致。name属性的value值表示映射文件所在包的路径。

 4、创建逆向工程的配置文件

 逆向工程配置文件名必须为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>
    <!--
targetRuntime: 执行生成的逆向工程的版本
MyBatis3Simple: 生成基本的CRUD(清新简洁版)
MyBatis3: 生成带条件的CRUD(奢华尊享版)
-->
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <!-- 数据库的连接信息 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                        connectionURL="jdbc:mysql://localhost:3306/review"
                        userId="root"
                        password="123456789">
        </jdbcConnection>
        <!--
            targetPackage:指定生成targetProject下的路径
            targetProject:指定生成的位置
        -->
        <!-- javaBean的生成策略-->
        <javaModelGenerator targetPackage="com.review.mybatis.pojo"
                            targetProject=".\src\main\java">
            <!--
                enableSubPackages设置是否能够使用子包,默认值为true,可以将包名中的‘.’解析为一个一个目录;
                如果为false,则无法解析包名中的‘.’,将带有'.'的包路径看作一个包。
             -->
            <property name="enableSubPackages" value="true"/>
            <!--
                trimStrings起截取作用,将表中的字段名前后的空格去除。
            -->
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>
        <!-- SQL映射文件的生成策略 -->
        <sqlMapGenerator targetPackage="com.review.mybatis.mapper"
                         targetProject=".\src\main\resources">
            <!--
                enableSubPackages:设置是否适用子包。
            -->
            <property name="enableSubPackages" value="true"/>
        </sqlMapGenerator>
        <!-- Mapper接口的生成策略 -->
        <javaClientGenerator type="XMLMAPPER"
                             targetPackage="com.review.mybatis.mapper" targetProject=".\src\main\java">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>
        <!-- 逆向分析的表 -->
        <!-- tableName:指定需要逆向生成的表
            tableName设置为*号时,可以对应所有表,此时不写domainObjectName -->
        <!-- domainObjectName:指定生成出来的实体类的类名 -->
        <table tableName="t_minister" domainObjectName="Minister"/>
        <table tableName="t_dutie" domainObjectName="Dutie"/>
    </context>
</generatorConfiguration>

 5、执行MBG插件的generate目标

 配置完generatorConfig文件后,需要执行generate插件生成逆向工程。生成逆向工程过程如下图,在maven仓库中找到当前工程下的mybatis-generator,双击mybatis-generator下的mybatis-generator:generate即可生成。

 NO.08 MyBatis创建逆向工程,mybatis,mybatis,数据库,java,开发语言,sql

 注意:如果当前工程main目录下只有resource目录,没有java目录,需手动创建java目录。

最终生成逆向工程的结果图:

NO.08 MyBatis创建逆向工程,mybatis,mybatis,数据库,java,开发语言,sql

逆向工程生成的Mapper接口中方法的使用参考NO.09 MyBatis中逆向工程生成的Mapper接口中的方法功能说明以及使用_qq_46053741的博客-CSDN博客文章来源地址https://www.toymoban.com/news/detail-670027.html

到了这里,关于NO.08 MyBatis创建逆向工程的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【MyBatis】五、MyBatis的缓存机制与逆向工程

    MyBatis的一级缓存是默认开启的,是基于SqlSession级别的缓存,也就是说,只要是同一个sqlSession,只要执行的语句相同,则不会去数据库中进行查找,而是会从缓存中找到对应的结果。 使用了不同的sqlsession对象 同一个sqlsession对象,但查询条件不同 两次查询之间进行了增删改

    2024年02月09日
    浏览(27)
  • MyBatis --- 缓存、逆向工程、分页插件

    一级缓存是SqlSession级别的,通过同一个SqlSession查询的数据会被缓存,下次查询相同的数据,就会从缓存中直接获取,不会从数据库重新访问 使一级缓存失效的四种情况: 1、不同的SqlSession对应不同的一级缓存 2、同一个SqlSession但是查询条件不同 3、同一个SqlSession两次查询期

    2023年04月09日
    浏览(28)
  • SpringBoot项目中使用mybatis逆向工程

    mybatis逆向工程,即利用现有的数据表结构,生成对应的model实体类、dao层接口,以及对应的mapper.xml映射文件。借助mybatis逆向工程,我们无需手动去创建这些文件。 下面是使用Java代码的方式来实现逆向工程,生成文件(也可以使用插件来生成): 首先,导入需要的依赖包:

    2024年02月08日
    浏览(36)
  • android 逆向工程(待续)

    资源汇总 reverse-engineering Android App Reverse Engineering 101 Awesome-Android-Reverse-Engineering ***** Awesome-Hacking 程绍银-中科大 Radare2 Radare2是一个强大的、开源的、跨平台的逆向工程框架和命令行工具。它主要用于分析、调试和操作二进制文件,包括但不限于 ELF、PE、Mach-O、DEX 和 RAW 等多种

    2024年02月04日
    浏览(35)
  • 解决xorm逆向工程问题

    问题 xorm : 无法将“xorm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。 今天在用xorm做逆向工程的时候碰到了一个普遍问题,xorm : 无法将“xorm”项识别为 cmdlet、函数、脚本文件或可运行程序的名

    2024年02月05日
    浏览(34)
  • Android 逆向工程,反编译心得

    apk的反编译是我们在Android开发中绕不开的一个坎,对于反编译这门技术,我们应该抱着学习的态度,学的越多,也越能防备别人反编译我们,这就是所谓的知己知彼吧,哈哈 Apktool ,解包和重新打包都需要它 dex-tools ,可以直接把apk中的classes.dex文件反编译为.jar文件 jd-gui ,

    2024年02月06日
    浏览(126)
  • ARM软件逆向工程入门 00

    ARM指令集是一种低功耗、小尺寸和低成本的指令集,它具有以下特点: ARM指令集具有良好的可移植性,可以在不同的架构上运行; ARM指令集支持32位和64位,减少指令的数量,提高运行效率; ARM指令集支持硬件加速,可以更有效的利用处理器的资源; ARM指令集可以节省系统

    2024年02月07日
    浏览(33)
  • AIGC:Prompt逆向工程简介及使用

    很多同学都会写爬虫。但如果想把爬虫写得好,那一定要掌握一些逆向技术,对网页的JavaScript和安卓App进行逆向,从而突破签名或者绕过反爬虫限制。最近半年,大语言模型异军突起,越来越多的公司基于GPT3.5、GPT-4或者其他大语言模型实现了各种高级功能。在使用大语言模

    2024年02月11日
    浏览(29)
  • 小程序逆向工程:这个开源的小程序逆向工具真不错,2023年亲测成功

    安全部门的大哥又双叒叕报了一个小程序的高危漏洞,他使用逆向工程破解了加密信心,用抓包修改了请求参数。又是头疼的一天… 想成为一名微信小程序的开发者,前端思路的学习和安全意识是非常有必要的,故务必掌握小程序反编译技能。 这里用到了2个工具《解密》与

    2023年04月19日
    浏览(41)
  • 【Spring】SpringBoot整合MybatisPlusGernerator,MybatisPlus逆向工程

       📝个人主页:哈__ 期待您的关注  在我们写项目的时候,我们时常会因为需要创建很多的项目结构而头疼。项目中的表很多的时候,我们连实体类都创建不完,这时候就需要我们的逆向工程来帮助我们生成我们的框架结构。这些结构都差不多,实体类,表现层,业务层和

    2024年04月15日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包