Mybatis-Genarator 逆向工程使用

个人开发环境

java环境:Jdk1.8.0_60

编译器:IntelliJ IDEA 2017.1.4

mysql驱动:mysql-connector-java-5.1.39.jar (用于你逆向工程使用)

Genarator 版本:mybatis-generator-maven-plugin (1.3.6)

源码连接:待整理

第一步 添加依赖

<!--springBoot相关-->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.9.RELEASE</version>
</parent> <!--约定版本-->
<properties>
<mybatis-spring-boot>1.2.0</mybatis-spring-boot>
<mysql-connector>5.1.39</mysql-connector>
</properties> <dependencies>
<!--springBoot相关-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency> <!--mybatis相关-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>${mybatis-spring-boot}</version>
</dependency> <!--mysql驱动相关-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency> <!--pojo实用小插件-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<!--依赖不传递-->
<optional>true</optional>
</dependency> </dependencies> <build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<!-- mybatis generator 自动生成代码插件 -->
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.6</version>
<configuration> <configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile>
<overwrite>true</overwrite>
<verbose>true</verbose>
</configuration>
</plugin>
</plugins>
</build>

第二步 配置文件

springboot 配置文件:application.yml(src/main/resources/application.yml)

server:
# 服务端口
port: 8083 spring:
datasource:
url: jdbc:mysql://localhost:3306/springcloud-mybatis
username: root
password: 123456
driver-class-name: com.mysql.jdbc.Driver # Mybatis 配置
mybatis:
typeAliasesPackage: com.fame.entity
mapperLocations: classpath:mapper/*.xml # 打印sql
logging:
level:
# 配置mapper接口的包路径
com.fame.mapper : debug

mybatis逆向工程配置文件:generatorConfig.xml(src/main/resources/generator/generatorConfig.xml)

1)配置数据信息 2)修改相关包名 3)配置相关表属性

<?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>
<!--mysql 连接数据库jar 这里选择自己本地位置-->
<classPathEntry location="D:/mysql-connector-java-5.1.39.jar" />
<context id="testTables" targetRuntime="MyBatis3">
<commentGenerator>
<!-- 是否去除自动生成的注释 true:是 : false:否 -->
<property name="suppressAllComments" value="true" />
</commentGenerator>
<!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/springcloud-mybatis" userId="root"
password="123456">
</jdbcConnection>
<!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 和
NUMERIC 类型解析为java.math.BigDecimal -->
<javaTypeResolver>
<property name="forceBigDecimals" value="true" />
</javaTypeResolver> <!-- targetProject:生成PO类的位置 -->
<javaModelGenerator targetPackage="com.fame.entity"
targetProject="src/main/java">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
<!-- 从数据库返回的值被清理前后的空格 -->
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!-- targetProject:mapper映射文件生成的位置
如果maven工程只是单独的一个工程,targetProject="src/main/java"
若果maven工程是分模块的工程,targetProject="所属模块的名称",例如:
targetProject="ecps-manager-mapper",下同-->
<sqlMapGenerator targetPackage="com.fame.mapper"
targetProject="src/main/java">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
</sqlMapGenerator>
<!-- targetPackage:mapper接口生成的位置 -->
<javaClientGenerator type="XMLMAPPER"
targetPackage="com.fame.mapper"
targetProject="src/main/java">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
</javaClientGenerator>
<!-- 指定数据库表 ,设置是否要生成Exemple方法-->
<table tableName="tb_user" schema=""
enableCountByExample="false"
enableDeleteByExample="false"
enableUpdateByExample="false"
enableSelectByExample="false"
selectByExampleQueryId="false">
<!--去除表明前缀tb_,注意严格控制大小写-->
<domainObjectRenamingRule searchString="^Tb" replaceString="" />
<!--去除列字段前缀,注意严格控制大小写-->
<columnRenamingRule searchString="^sys" replaceString=""/>
</table>
</context>
</generatorConfiguration>
<?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>
<!--mysql 连接数据库jar 这里选择自己本地位置-->
<classPathEntry location="D:/mysql-connector-java-5.1.39.jar" />
<context id="testTables" targetRuntime="MyBatis3">
<commentGenerator>
<!-- 是否去除自动生成的注释 true:是 : false:否 -->
<property name="suppressAllComments" value="true" />
</commentGenerator>
<!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/springcloud-mybatis" userId="root"
password="123456">
</jdbcConnection>
<!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 和
NUMERIC 类型解析为java.math.BigDecimal -->
<javaTypeResolver>
<property name="forceBigDecimals" value="true" />
</javaTypeResolver> <!-- targetProject:生成PO类的位置 -->
<javaModelGenerator targetPackage="com.fame.entity"
targetProject="src/main/java">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
<!-- 从数据库返回的值被清理前后的空格 -->
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!-- targetProject:mapper映射文件生成的位置
如果maven工程只是单独的一个工程,targetProject="src/main/java"
若果maven工程是分模块的工程,targetProject="所属模块的名称",例如:
targetProject="ecps-manager-mapper",下同-->
<sqlMapGenerator targetPackage="com.fame.mapper"
targetProject="src/main/java">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
</sqlMapGenerator>
<!-- targetPackage:mapper接口生成的位置 -->
<javaClientGenerator type="XMLMAPPER"
targetPackage="com.fame.mapper"
targetProject="src/main/java">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false" />
</javaClientGenerator>
<!-- 指定数据库表 ,设置是否要生成Exemple方法-->
<table tableName="tb_user" schema=""
enableCountByExample="false"
enableDeleteByExample="false"
enableUpdateByExample="false"
enableSelectByExample="false"
selectByExampleQueryId="false">
<!--去除表明前缀tb_,注意严格控制大小写-->
<domainObjectRenamingRule searchString="^Tb" replaceString="" />
<!--去除列字段前缀,注意严格控制大小写-->
<columnRenamingRule searchString="^sys" replaceString=""/>
</table>
</context>
</generatorConfiguration>

第三步 逆向工程

方式一

创建generator配置文件,启动即可

方式二

点击IDEA右侧Maven Project 双击Plugins下的mybatis-generator

其中,方式一配置好的文件,也可以在Run Configurations双击启动

注意:生成的XXXMapper.xml,需要放到(src/main/resource)下.

原因:IDEA不编译src的java目录下的xml文件

第四步 创建Application启动类

如果是直接创建springboot项目可忽略这一步,我是直接创建的一个Maven项目进行整合。

注意:加入注解@MapperScan进行mapper接口扫描

@SpringBootApplication
// mapper 接口类扫描包配置
@MapperScan("com.fame.mapper")
public class MybatisApplication {
public static void main(String[] args) {
SpringApplication.run(MybatisApplication.class, args);
}
}

这样就整合完成,可以创建接口进行单元测试了

第五步 实例简单测试

新增(insert)

/**
* mybatis generator逆向工程 新增测试
*
* @param user 用户信息
*/
@PostMapping("/add")
public void add(@RequestBody User user) { // 直接新增
userMapper.insert(user); // 新增会做非空判断
userMapper.insertSelective(user);
}

修改(update)

/**
* mybatis generator逆向工程 查询测试
*
* @param userId 用户ID
*/
@PutMapping("/update")
public void update(Long userId) {
User user = userMapper.selectByPrimaryKey(userId); // 通过ID 修改
user.setUsername("大白generator 测试修改操作");
// updateByPrimaryKey 全修改
userMapper.updateByPrimaryKey(user);
// updateByPrimaryKeySelective 选择user对象不为null 的修改
userMapper.updateByPrimaryKeySelective(user); // 使用Example Criteria 通过关键字修改
UserExample userEmp = new UserExample();
userEmp.or().andIdEqualTo(userId);
// updateByExample 全修改
userMapper.updateByExample(user, userEmp);
// updateByExampleSelective 选择user对象不为null 的修改
userMapper.updateByExampleSelective(user, userEmp); }

删除(delete)

/**
* mybatis generator逆向工程 查询测试
*
* @param userId 用户ID
*/
@DeleteMapping("/delete")
public void delete(Long userId) { // 通过ID 删除
userMapper.deleteByPrimaryKey(userId); // 使用Example Criteria 通过关键字删除
UserExample userEmp = new UserExample();
userEmp.or().andIdEqualTo(userId);
userMapper.deleteByExample(userEmp);
}

查询(select)

/**
* mybatis generator逆向工程 查询测试
*
* @param userId 用户ID
*/
@GetMapping("/get")
public void get(Long userId) { // 通过主键ID 获取用户信息
User user = userMapper.selectByPrimaryKey(userId);
System.out.println(user); // 通过example Criteria 查询
// where id = ?
UserExample userEmp = new UserExample();
userEmp.or().andIdEqualTo(userId);
List<User> users1 = userMapper.selectByExample(userEmp);
System.out.println(users1.get(0)); userEmp.clear();
// where ( id = ? and username =? ) or ( id = ? and age =? )
userEmp.or().andIdEqualTo(userId).andUsernameEqualTo("大白1");
userEmp.or().andIdEqualTo(userId).andAgeEqualTo(22);
List<User> users2 = userMapper.selectByExample(userEmp);
System.out.println(users2.get(0));
}

合计(count)

/**
* mybatis generator逆向工程 合计测试
*/
@GetMapping("/count")
public void count(){ // 查询全部数据
long countAll = userMapper.countByExample(new UserExample());
System.out.println(countAll); // 查询满足条件的数据
UserExample userEmp = new UserExample();
userEmp.or().andIdEqualTo(1L);
long countByKey = userMapper.countByExample(userEmp);
System.out.println(countByKey);
}

SpringBoot+Mybatis+Generator 逆向工程使用(二)的更多相关文章

  1. Java逆向工程SpringBoot + Mybatis Generator + MySQL

    Java逆向工程SpringBoot+ Mybatis Generator + MySQL Meven pop.xml文件添加引用: <dependency> <groupId> ...

  2. Springboot & Mybatis 构建restful 服务二

    Springboot & Mybatis 构建restful 服务二 1 前置条件 成功执行完Springboot & Mybatis 构建restful 服务一 2 restful ...

  3. Mybatis Generator逆向工程的使用

    一.在 idea 中使用 mybatis generator 逆向工程 1.在IDEA上创建maven工程. 2.在pom.xml中配置MyBatis逆向工程插件 <!--MyBatis自动生成 ...

  4. springboot(十三):springboot结合mybatis generator逆向工程自动生成代码

    错信息generate failed: Exception getting JDBC Driver: com.mysql.jdbc.Driver 上网查了一下,发现原来是generator这个插件在运 ...

  5. 在IDEA中使用MyBatis Generator逆向工程生成代码

    本文介绍一下用Maven工具如何生成Mybatis的代码及映射的文件. 一.配置Maven pom.xml 文件 在pom.xml增加以下插件: <build> <finalName ...

  6. Springboot+Mybatis的逆向工程

    Mybatis逆向工程,自动生成 entity类和常用的增删改查方法. 1.pom.xml引入类 <!-- 通用mapper 用于mabatis封装的基础增删改查的功能--><dep ...

  7. javaweb各种框架组合案例(五):springboot+mybatis+generator

    一.介绍 1.springboot是spring项目的总结+整合 当我们搭smm,ssh,ssjdbc等组合框架时,各种配置不胜其烦,不仅是配置问题,在添加各种依赖时也是让人头疼,关键有些jar包之间 ...

  8. mybatis学习系列四--mybatis generator逆向工程

    采用命令行方式执行逆向工程 1.配置文件generatorConfig.xml 保存在目录:D:\E\workspace\eclipse\mybatis_generator <?xmlversi ...

  9. MyBatis -- generator 逆向工程

    一.引言 官网文档:http://www.mybatis.org/generator/index.html 通过使用官方提供的mapper自动生成工具,mybatis-generator-core-1 ...

随机推荐

  1. session和cookie的异同

    Cookie是服务器发给客户端的一小段文本,保存在浏览器所在客户端的内存和磁盘上.服务器可以从客户端读出这些cookie.通过cookie,客户端可以和服务器端建立起一种联系,也就是说,Cookie是 ...

  2. 七,apache配置域名

    配置域名服务器流程: (1)在httpd.conf中启用虚拟主机,Include conf/extra/httpd-vhosts.conf前面的#去掉. (2)在httpd.conf中修改项目路径为自 ...

  3. JVM概念总结:数据类型、堆与栈

    Java虚拟机中,数据类型可以分为两类:基本类型和引用类型.基本类型的变量保存原始值,即:他代表的值就是数值本身: 引用类型的变量保存引用值,引用值代表了某个对象的引用而不是对象的本身,对象的本身存放 ...

  4. xss跨站脚本攻击汇总

  5. D06——C语言基础学PYTHON

    C语言基础学习PYTHON——基础学习D06 20180821内容纲要: 面向对象初级学习 1 面向对象 2 类 (1)封装 (2)继承 (3)多态 3 小结 4 练习:选课系统 5 课外拓展:答题系 ...

  6. 批量导入数据到HBase

    hbase一般用于大数据的批量分析,所以在很多情况下需要将大量数据从外部导入到hbase中,hbase提供了一种导入数据的方式,主要用于批量导入大量数据,即importtsv工具,用法如下:   Us ...

  7. PHP CURL 抓取失败 自己调试

    蛋疼的一下午,物理机win7旗舰版+APACHE2 ,CURL抓取一直成功. 虚拟机ubuntu+apache2一直抓取失败. 晚上,问个仁兄才知道,CURL可以调试: 参考这位兄台: 地址 curl ...

  8. postman—环境切换和设置变量

    postman提供了environment管理功能,想要在多个环境中测试,比如在测试环境.灰度环境.生产环境等,只需要用同样的接口,切换下环境即可,非常方便.具体步骤: 一.切换环境 1.点击界面右上 ...

  9. Android4.0 Launcher 源码分析3——WorkSpace结构(滑动)

    3.WorkSpace结构(滑动) 桌面的左右滑动功能主要是在PagedView类中实现的,而WorkSpace是PagedView类的子类,所以会继承PagedView中的方法.当我们的手指点击Wo ...

  10. Mina的客户端

    (一) package client; import java.net.InetSocketAddress; import java.nio.charset.Charset; import org.a ...