SpringBoot2.x 自动化生成代码整合Mybatis
前言
Mybatis 是一个持久层ORM框架,负责Java与数据库数据交互,也可以简易理解为中介,相对于它,还有个中介是hibernate,不过在mybatis中sql语句的灵活性,可优化性比较强,这也是现在大多数人选择的原因。
1. mapper.xml、dao接口、实体类自动生成
下载 pan.baidu.com/s/1JY7Xduk5… 工具包
1.1 修改配置文件generator.xml
解压之后,这里把文件拷贝到了C:\resources\generator文件夹下,以下称为"当前文件目录"
一次配置,终身受益
generator.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><!-- 数据库驱动包位置 也就是刚解压的文件的位置加上 mysql-connector-java-5.1.34.jar--><classPathEntry location="C:\resources\generator\mysql-connector-java-5.1.34.jar" /><!--这里也适用Oracle数据库的自动生成--><!-- <classPathEntry location="C:\resources\generator\ojdbc6.jar" /> --><context id="DB2Tables" targetRuntime="MyBatis3"><commentGenerator><!-- 去除生成日期 --><property name="suppressDate" value="true"/><!-- 去除所有的注解 --><property name="suppressAllComments" value="true"/></commentGenerator><!-- 数据库链接URL、用户名、密码 --><jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/ceilan" userId="root" password="123456"><!-- <jdbcConnection driverClass="oracle.jdbc.driver.OracleDriver" connectionURL="jdbc:oracle:thin:@localhost:1521:orcl" userId="scott" password="tiger">--></jdbcConnection><!--java类型处理器--><javaTypeResolver><property name="forceBigDecimals" value="false" /></javaTypeResolver><!-- 生成模型的包名和位置 --><javaModelGenerator targetPackage="com.example.entity" targetProject="C:\resources\generator\src"><property name="enableSubPackages" value="true" /><property name="trimStrings" value="true" /></javaModelGenerator><!-- 生成的映射文件包名和位置 --><sqlMapGenerator targetPackage="mapping" targetProject="C:\resources\generator\src"><property name="enableSubPackages" value="true" /></sqlMapGenerator><!-- 生成DAO的包名和位置 --><javaClientGenerator type="XMLMAPPER" targetPackage="com.example.dao" targetProject="C:\resources\generator\src"><property name="enableSubPackages" value="true" /></javaClientGenerator><!-- 要生成哪个表,更改tableName(数据库里表名)和domainObjectName(实体名,一般首字母大写)就可以 --><table tableName="area" domainObjectName="Area" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false" /></context>
</generatorConfiguration>
1.2 用Java运行自动生成
在当前目录下打开cmd命令,运行如下
注 : windows系统可直接执行 [ 生成.bat ] 批处理文件
java -jar mybatis-generator-core-1.3.2.jar -configfile generator.xml -overwrite
然后把当前目录src下的com文件夹拷贝到项目文件夹下
把mapping文件拷贝到resources文件夹下
目录结构如上
2.集成Mybatis框架
2.1 引入依赖
compile "mysql:mysql-connector-java:5.1.39"
compile 'org.mybatis.spring.boot:mybatis-spring-boot-starter:1.2.0'
2.2 启动类DemoApplication.java增加扫描配置
package com.example;import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;@SpringBootApplication
// mapper接口 扫描包配置
@MapperScan(value = "com.example.dao")
public class DemoApplication {public static void main(String[] args) {SpringApplication.run(DemoApplication.class, args);}
}
2.3 添加项目首页index.html
在resources的templates文件中新建index.html
index.html
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body><h1>Welcome SpringBoot</h1>
</body>
</html>
然后在 DemoApplication 启动类中添加
//欢迎页面 首页@RequestMapping("/")public String index(){return "index";}
之前已经在application.yml中配置了资源映射设置,如下
spring: mvc:view:suffix: .htmlresources:static-locations: classpath:/templates
所以现在的项目启动访问 http://localhost:8080/ 是可以直接访问到首页的
3.添加业务层和控制层实现CRUD(增删改查)
增加业务逻辑层包service以及在其下增加impl包用来实现其接口
3.1业务逻辑层接口 AreaService.java
package com.example.service;import com.example.entity.Area;/*** 这里给dao层的代码拷贝过来先使用* created by cfa 2018-11-08 下午 9:56**/
public interface AreaService {int deleteByPrimaryKey(Integer id);int insert(Area record);int insertSelective(Area record);Area selectByPrimaryKey(Integer id);int updateByPrimaryKeySelective(Area record);int updateByPrimaryKey(Area record);
}
3.2业务层实现类 AreaServiceImpl.java
package com.example.service.impl;import com.example.dao.AreaMapper;
import com.example.entity.Area;
import com.example.service.AreaService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.io.Serializable;/*** 这里的@Service注解相当于自动注册到Spring的Bean* 相当于原来的Application.xml里的 <bean id="areaServiceImpl" class="com.example.service.impl.AreaServiceImpl"/>* created by cfa 2018-11-08 下午 9:58**/
@Service
public class AreaServiceImpl implements AreaService, Serializable {private final AreaMapper areaMapper;@Autowiredpublic AreaServiceImpl(AreaMapper areaMapper) {this.areaMapper = areaMapper;}@Overridepublic int deleteByPrimaryKey(Integer id) {return areaMapper.deleteByPrimaryKey(id);}@Overridepublic int insert(Area record) {return areaMapper.insert(record);}@Overridepublic int insertSelective(Area record) {return areaMapper.insertSelective(record);}@Overridepublic Area selectByPrimaryKey(Integer id) {return areaMapper.selectByPrimaryKey(id);}@Overridepublic int updateByPrimaryKeySelective(Area record) {return areaMapper.updateByPrimaryKeySelective(record);}@Overridepublic int updateByPrimaryKey(Area record) {return areaMapper.updateByPrimaryKey(record);}
}
3.3控制层的AreaController.java
package com.example.controller;import com.example.entity.Area;
import com.example.service.AreaService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("area")
public class AreaController {private final AreaService areaService;@Autowiredpublic AreaController(AreaService areaService) {this.areaService = areaService;}@RequestMapping("query")public Area areaList(){return areaService.selectByPrimaryKey(1);}}
看到这里,想必看到很多次@Autowired,@Service等注解了,这就是Spring的两大核心之一的IOC(Inversion of Control),也就是DI依赖注入;
Spring的两大核心AOP和IOC大家面试的时候也基本都有问到,到这里你IOC就不用头疼了;
在Spring之前我们写代码,用到某个类,我们都需要去new一下,现在有个叫Spring,我把控制权交给它,OK,然后在给业务层盖上章(加注解),然后让这个叫Spring的家伙开始工作的时候,交给他去做,控制层需要逻辑A,OK,之前我们已经在控制层用DI注入了A,Spring就会把A的调用给控制层,下面说松紧耦合度,Spring之前,到处写的都是new新建对象,修改一个类很难,现在随意修改,只需要盖个章(DI),让Spring去管就可以了,你现在要问我原理,那些文邹邹的,后续在研究研究,原理相当于文言文,只有研究透了,才能用大家都理解的话写出来。
业务层提供的接口加实现类就是为了实现松耦合,不然一个类就解决了,就像一个手机,坏了,里面的电池,屏幕,主板什么的拆下来还能用,这就是松耦合。
4.热部署插件
问题:你为什么不选择springboot自带的热部署插件
答: 和之前的朋友问我的一样,问我为啥不把生成代码的插件放在项目中,一个项目还好,你要是写了多个项目,一个一个去部署,麻烦不,所以一次配置,一劳永逸。
5.关于AOP——Spring的又一大核心
面向切面编程(AOP是Aspect Oriented Program的首字母缩写)我们知道,面向对象的特点是继承、多态和封装.而封装就要求将功能分散到不同的对象中去,这在软件设计中往往称为职责分配.实际上也就是说,让不同的类设计不同的方法。这样代码就分散到一个个的类中去了。这样做的好处是降低了代码的复杂程度,使类可重用.但是人们也发现,在分散代码的同时,也增加了代码的重复性.什么意思呢?比如说,我们在两个类中,可能都需要在每个方法中做日志。按面向对象的设计方法,我们就必须在两个类的方法中都加入日志的内容。也许他们是完全相同的,但就是因为面向对象的设计让类与类之间无法联系,而不能将这些重复的代码统一起来。 也许有人会说,那好办啊,我们可以将这段代码写在一个独立的类独立的方法里,然后再在这两个类中调用。但是,这样一来,这两个类跟我们上面提到的独立的类就有耦合了,它的改变会影响这两个类。那么,有没有什么办法,能让我们在需要的时候,随意地加入代码呢?这种在运行时,动态地将代码切入到类的指定方法、 指定位置上的编程思想就是面向切面的编程。 一般而言,我们管切入到指定类指定方法的代码片段称为切面,而切入到哪些类、哪些方法则叫切入点。有了AOP,我们就可以把几个类共有的代码,抽取到一个切片中,等到需要时再切入对象中去,从而改变其原有的行为。 这样看来,AOP其实只是OOP的补充而已。OOP从横向上区分出一个个的类来,而AOP则从纵向上向对象中加入特定的代码。有了AOP,OOP变得立体了。如果加上时间维度,AOP使OOP由原来的二维变为三维了,由平面变成立体了。从技术上来说,AOP基本上是通过代理机制实现的。 AOP在编程历史上可以说是里程碑式的,对OOP编程是一种十分有益的补充 引自:xiaobashagua.iteye.com/blog/196368…你问我为啥排这么紧,哈哈,好东西是留给有耐心的人看的,如果你把这篇文章的IOC和AOP仔细看了,你会对这俩的理解又深了一个层次
SpringBoot2.x 自动化生成代码整合Mybatis相关推荐
- SpringBoot2.x【四】自动化生成代码整合Mybatis
SpringBoot2.x[四]自动化生成代码整合Mybatis Mybatis 是一个持久层ORM框架,负责Java与数据库数据交互,也可以简易理解为中介,相对于它,还有个中介是hibernate, ...
- 【哪些工作会被ChatGPT取代?】我用ChatGPT全自动化生成代码进行了深度分析
[哪些工作会被ChatGPT取代?]我用ChatGPT全自动化生成代码进行了深度分析 前言 配置好ChatGPT的几个小时之后,我发现了一个宝藏网页https://github.com/f/aweso ...
- mybatis根据表逆向自动化生成代码(自动生成实体类、mapper文件、mapper.xml文件)
若采用mybatis框架,数据库新建表,手动编写的话,需要编写大量的实体类.mapper文件.mapper.xml文件,都是一些重复且有规律的工作. 我们可以引用插件,然后做配置,自动生成这些文件,提 ...
- Python自动化生成代码以及验证代码汇总
python 软件自动化 0 绪 1. 自动打开.编译.下载: 1.1 自动打开工程,打开软件 1.2. 自动点击编译,下载按钮, 2. 自动写代码 2.1 对工程进行更改 2.2 对C文件更改 3 ...
- MyBatisPlus自动生成代码springboot+mybatis+mysql 以及动态sql生成方法(测试可用版)
用了一段时间的springboot,想着百度一下自动生成代码的方式,包括后面如何生成动态sql方法的方式. 摸索了几天,整理一下: ** 1 自动生成代码方式:com.baomidou.mybatis ...
- SpringBoot如何自动生成实体类和Dao层以及映射文件(mybatis generator 自动生成代码)
一.首先添加自动生成代码插件 <!-- mybatis generator 自动生成代码插件 生成时解除注释 --><plugin><groupId>org.myb ...
- 自定义注解生成代码(三) 之javapoet案例实战
自定义注解生成代码(三) 之javapoet案例实战 前面两个章节主要介绍了 javapoet 的基础语法和基本使用,感兴趣的同学可以查看博客 自定义注解生成代码(一)之 javaPoetAPI详解 ...
- Thinkphp 6 + Vue 2 + ElementUI + Vxe-table 前后端分离的,一键生成代码和API接口的,通用后台管理系统 快速开发框架,开发小程序和APP的推荐框架!
Thinkphp 6 + Vue 2 + ElementUI + Vxe-table 前后端分离的,一键生成代码和API接口的,通用后台管理系统 快速开发框架,开发小程序和APP的推荐框架! 概述 R ...
- SpringBoot入门篇--整合mybatis+generator自动生成代码+druid连接池+PageHelper分页插件
我们这一一篇博客讲的是如何整合Springboot和Mybatis框架,然后使用generator自动生成mapper,pojo等文件.然后再使用阿里巴巴提供的开源连接池druid,这个连接池的好处我 ...
最新文章
- 使用组策略实现文件复制
- 利用OpenCV的级联分类器类CascadeClassifier和Haar特征实现人脸区域的检测
- python强制可读吗_python 中的强制类型转换
- 中国非动物胶市场来产销需求及发展潜力研究报告2022版
- 【物联网】OpenWrt编译出现Unable to find remote helper for 'https'问题
- Cookie和Session的区别详解
- electron 读取文件夹内容_如何使用Electron Framework选择,读取,保存,删除或创建文件...
- ArrayList 去重
- python模块之logging模块
- 算法笔记_面试题_18.动态规划_模板及示例十几道(上)
- tomcat配置管理员帐号密码
- 3.1词典搜索的数据结构与通配符查询
- 基于SSM框架的电影订票系统
- 队列、栈以及双端队列
- MySQL如何创建视图和用户
- 电信宽带华为HG8245光纤猫开路由、WIFI的破解办法
- php中errorreporting,php中error_reporting函数用法详解_PHP教程
- 第一章 Xadmin简介
- android向DDR读写数据,透过数据看本质 - 被“吹爆”的LPDDR5内存究竟有多强大?...
- 基于FPGA的VGA/LCD显示控制器设计(中)