Mybatis 逆向工程使用(Day_17)
有三个方法可以解决所有的问题:接受,改变,离开。不能接受那就改变,不能改变,那就离开。
【何为逆向工程?】
众 所 周 知 ,正向工程就是通过JAVA类的设置来生成对应的数据库表。
MyBatis逆向工程,就是使用官方网站的mapper自动生成工具mybatis-generator-core-1.3.2来生成po类和mapper映射文件(单表增删改查)。
mybatis需要编写sql语句,mybatis官方提供逆向工程,可以针对单表自动生成mybatis执行所需要的代码(mapper.java、mapper.xml、pojo…),提高工作效率。
【使用工具】
IntelliJ IDEA 2018.3
【官网】
https://mybatis.org/mybatis-3
【使用步骤】
(1)、添加POM依赖
1 <dependencies>
2 <!--逆向工程需要使用到mybatis-generator-core-->
3 <dependency>
4 <groupId>org.mybatis.generator</groupId>
5 <artifactId>mybatis-generator-core</artifactId>
6 <version>1.3.7</version>
7 </dependency>
8 <!--本次操作中使用的mybatis-->
9 <dependency>
10 <groupId>org.mybatis</groupId>
11 <artifactId>mybatis</artifactId>
12 <version>3.5.6</version>
13 </dependency>
14 <!--连接数据库所需的依赖-->
15 <dependency>
16 <groupId>mysql</groupId>
17 <artifactId>mysql-connector-java</artifactId>
18 <version>5.1.48</version>
19 </dependency>
20 </dependencies>
(2)、新增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 <properties resource="database.properties"/>
8 <context id="testTables" targetRuntime="MyBatis3">
9 <commentGenerator>
10 <!-- 是否去除自动生成的注释 true:是 : false:否 -->
11 <property name="suppressAllComments" value="true" />
12 </commentGenerator>
13 <!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
14 <jdbcConnection driverClass="${driver}"
15 connectionURL="${url}" userId="${username}"
16 password="${password}">
17 </jdbcConnection>
18 <!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL
19 和 NUMERIC 类型解析为java.math.BigDecimal -->
20 <javaTypeResolver>
21 <property name="forceBigDecimals" value="false" />
22 </javaTypeResolver>
23
24 <!-- targetProject:生成PO类的位置 -->
25 <javaModelGenerator targetPackage="com.papercy.smbms.pojo"
26 targetProject=".\src\main\java">
27 <!-- enableSubPackages:是否让schema作为包的后缀 -->
28 <property name="enableSubPackages" value="false" />
29 <!-- 从数据库返回的值被清理前后的空格 -->
30 <property name="trimStrings" value="true" />
31 </javaModelGenerator>
32 <!-- targetProject:mapper映射文件生成的位置 -->
33 <sqlMapGenerator targetPackage="com.papercy.smbms.mapper"
34 targetProject=".\src\main\java">
35 <!-- enableSubPackages:是否让schema作为包的后缀 -->
36 <property name="enableSubPackages" value="false" />
37 </sqlMapGenerator>
38 <!-- targetPackage:mapper接口生成的位置 -->
39 <javaClientGenerator type="XMLMAPPER"
40 targetPackage="com.papercy.smbms.mapper" targetProject=".\src\main\java">
41 <!-- enableSubPackages:是否让schema作为包的后缀 -->
42 <property name="enableSubPackages" value="false" />
43 </javaClientGenerator>
44 <!-- 指定数据库表 -->
45 <table schema="" tableName="smbms_user" domainObjectName="User"></table>
46 <table schema="" tableName="smbms_role" domainObjectName="Role"></table>
47 <table schema="" tableName="smbms_provider" domainObjectName="Provider"></table>
48 <table schema="" tableName="smbms_bill" domainObjectName="Bill"></table>
49 <table schema="" tableName="smbms_address" domainObjectName="Address"></table>
50
51 </context>
52 </generatorConfiguration>
(3)、properties 文件
1 driver=com.mysql.jdbc.Driver
2 url=jdbc:mysql://localhost/smbms?useUnicode=true&characterEncoding=UTF-8
3 username=root
4 password=123456
(4)、添加主程序运行项目
GeneratorSqlmap.java 文件:
1 import org.mybatis.generator.api.MyBatisGenerator;
2 import org.mybatis.generator.config.Configuration;
3 import org.mybatis.generator.config.xml.ConfigurationParser;
4 import org.mybatis.generator.internal.DefaultShellCallback;
5
6 import java.io.File;
7 import java.util.ArrayList;
8 import java.util.List;
9
10 public class GeneratorSqlmap {
11
12 public void generator() throws Exception {
13
14 List<String> warnings = new ArrayList<String>();
15 boolean overwrite = true;
16 // 指定 逆向工程配置文件(绝对路径)
17 File configFile = new File("C:\\PapercyFile\\IDEADemo\\mbatis10\\src\\main\\resources\\generatorConfig.xml");
18 ConfigurationParser cp = new ConfigurationParser(warnings);
19 Configuration config = cp.parseConfiguration(configFile);
20 DefaultShellCallback callback = new DefaultShellCallback(overwrite);
21 MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
22 myBatisGenerator.generate(null);
23
24 }
25
26 public static void main(String[] args) throws Exception {
27 try {
28 GeneratorSqlmap generatorSqlmap = new GeneratorSqlmap();
29 generatorSqlmap.generator();
30 } catch (Exception e) {
31 e.printStackTrace();
32 }
33
34 }
35
36 }
(5)、可能xml文件有不识别现象,在 POM 中添加如下代码。
1 <build>
2 <resources>
3 <resource>
4 <directory>${basedir}/src/main/java</directory>
5 <includes>
6 <include>**/*.xml</include>
7 </includes>
8 </resource>
9 </resources>
10 </build>
(6)、最后执行主程序GeneratorSqlmap,得到结果如图所示,pojo,mapper映射文件:
【结束语】
至此,Mybatis 逆向工程使用 就告一段落了,本篇博客只是使用主程序运行来生成逆向工程,
还有 使用插件 从而运行逆向工程的。 简单介绍下:
mybatis-generator-core :进入https://mvnrepository.com/搜索 MyBatis ,找到 MyBatis Generator Core
如下图 :
从而使用此插件实现逆向工程。
推荐一篇比较详细的使用插件实现逆向工程的(博客):
https://www.cnblogs.com/xqz0618/p/javaweb05.html
我是肥肥也,喜欢就点点【关注】,不喜欢也没关系,喜欢我的人多了去了,又不差你一个~
See you
Mybatis 逆向工程使用(Day_17)的更多相关文章
- mybatis0212 mybatis逆向工程 (MyBatis Generator)
1mybatis逆向工程 (MyBatis Generator) .1什么是mybatis的逆向工程 mybatis官方为了提高开发效率,提高自动对单表生成sql,包括生成 :mapper.xml.m ...
- 【JAVA - SSM】之MyBatis逆向工程的使用
MyBatis逆向工程可以方便的从数据库中将表自动映射到JAVA POJO类,并同时生成Mapper.xml和Mapper接口,方便实用.下面介绍一下逆向工程的使用方法. 使用逆向工程,我们最好是新建 ...
- Mybatis 逆向工程
Mybatis逆向工程: 推荐用Java和XML Configuration的方式生成逆向文件 Java类: package generation; import java.io.File; impo ...
- mybatis逆向工程
一.背景 在实际开发中我们会自己去写mapper映射文件,接口,数据库表对应的实体类,如果需求任务比较少,咱们还可以慢慢的一个一个去写,但是这是不现实的,因为在工作中我们的任务是很多的,这时mybat ...
- JAVAEE——Mybatis第二天:输入和输出映射、动态sql、关联查询、Mybatis整合spring、Mybatis逆向工程
1. 学习计划 1.输入映射和输出映射 a) 输入参数映射 b) 返回值映射 2.动态sql a) If标签 b) Where标签 c) Sql片段 d) Foreach标签 3.关联查询 a) 一对 ...
- mybatis框架(7)---mybatis逆向工程
mybatis逆向工程 逆向工程的目的就是缩减了我们的开发时间.所谓mybatis逆向工程,就是mybatis会根据我们设计好的数据表,自动生成pojo.mapper以及mapper.xml. 接 ...
- 学习笔记01(mybatis逆向工程)
今天来看看一个常用的小功能,就是mybatis的逆向工程.(数据库是mysql) 什么是逆向工程呢?看名字就知道反方向的一个什么工程! 其实啊,如果是平常我们自己学习实践一些小项目的时候,应该是先瞎写 ...
- mybatis逆向工程的注意事项,以及数据库表
1.选择性更新,如果有新参数就更换成新参数,如果参数是null就不更新,还是原来的参数 2.mybatis使用逆向工程,数据库建表的字段user_id必须用下滑线隔开,这样生成的对象private L ...
- IDEA Maven项目的Mybatis逆向工程
IDEA Maven项目的Mybatis逆向工程 1.配置.pom 如果是在多模块开发下,该文件逆向工程要生成的那个模块下的pom文件. <build> <plugins> & ...
随机推荐
- Foreign Exchange UVA - 10763
Your non-profit organization (iCORE - international Confederation of Revolver Enthusiasts) coordin ...
- Day09_42_Set集合_HashSet
集合之HashSet * HashSet - HashSet无序不可重复,HashSet底层实际上是一个HashMap,HashMap底层采用了Hash表数据结构. - 哈希表又叫做散列表,哈希表底层 ...
- 【Vue】Vue学习(四)-状态管理中心Vuex的简单使用
一.vuex的简介 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.Vuex背后的基本思想,就是前面所说的单向数据流.图4就是Vuex实现单向数据流的示意图. Store ...
- LA2965侏罗纪(异或和为0的最大数字个数)
题意: 给你n个字符串,让你在里面找到一个字符串集合使得这些字符串中所有的字母出现的次数和为偶数,输出集合的最大个数,和ASCII最小的解. 思路: 考虑到每个字符串中所有的字 ...
- Python脚本暴力破解FTP口令(ftplib)
目录 判断FTP服务器是否允许匿名登录 暴力破解FTP口令 列出FTP目录内的网页文件 综合 环境:Windows python2.7.15 ftplib模块是python下用于ftp服务的模块 . ...
- Docker用Commit给容器做快照
关于 commit 镜像是容器的基础,每次执行 docker run 的时候都会指定哪个镜像作为容器运行的基础. 镜像是多层存储,每一层是在前一层的基础上进行修改:而容器同样也是多层存储,是在以镜像为 ...
- Win64 驱动内核编程-28.枚举消息钩子
枚举消息钩子 简单粘贴点百度的解释,科普下消息钩子: 钩子是WINDOWS中消息处理机制的一个要点,通过安装各种钩子,应用程序能够设置相应的子例程来监视系统里的消息传递以及在这些消息到达目标窗口程序之 ...
- XCTF-i-get-id-200
i-get-id-200 题目描述 嗯..我刚建好了一个网站 解题过程 一共有三个页面 Hello World 告诉了页面是perl写的 Forms 输入name和age会返回渲染后的字符串 搜了一下 ...
- 『政善治』Postman工具 — 7、Postman中保存请求(Collections集合)
目录 1.创建Collection 2.保存Request请求 3.查看保存的请求 4.Collection下还可以创建文件夹 5.补充:Postman中的变量 6.总结 1.创建Collection ...
- IOCP实现高并发以及与传统socke编程的对比
前言 传统socket编程中服务端一般为每一个客户端创建一个线程(一对一).这样虽然可以使程序的结构简单明了并且方便对数据处理,但是这些都是建立在创建多个线程的基础上,也就是以牺牲线程为代价.一旦有大 ...