通用Mapper使用
通用Mapper介绍
产生背景
使用Mybatis的开发者大多会因为繁多的XML映射配置而头痛不已,即使使用注解,大量的SQL语句也是不可避免的,当数据库表结构发生变动时,所有对应的sql和实体类都得修改,基于此,通用Mapper出现了
基本概念
通用Mapper是一款用于单表增删改查的Mybatis插件,开发人员可以省去编写sql语句和在DAO层编写任何方法,就能轻松实现单表的常用操作。
项目地址
支持国产,从我做起。通用Mapper的作者是一位国人。项目地址:
环境导入
环境说明
平台:windows
jdk版本:1.8
IDE:IDEA
数据库:mysql(8)
项目创建
新建一个Springboot项目
新建项目就没啥好说了,使用IDEA自带的Spring Initializer,一直下一步就完事了,省心
添加通用mapper依赖
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper-spring-boot-starter</artifactId>
<version>2.1.5</version>
</dependency>
SpringBoot配置文件
#JDBC配置
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
spring.datasource.username=root
spring.datasource.password=root
#mybatis配置
mybatis.configuration.map-underscore-to-camel-case=true logging.level.root = debug
数据准备
- 建表语句
create table user(
id int(10) auto_increment primary key,
name varchar(20) null,
email varchar(50) null
);
实体类编写
package com.panda.domain;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
@Table(name = "user")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@Column
private String name;
@Column
private String email;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
}
说明
表名默认使用类名,驼峰会转换为下划线,如UserInfo对应的表名为user_info.当不满足上述对应关系时,类名上使用@Table注解,使用name属性指定tableName;
类的属性名默认会采用驼峰法转换为表字段名,如userName转化为user_name;不满足上述对应关系时,字段名上使用@Column注解,使用name属性指定表字段名;
表字段没有的属性,可以使用@Transient注解。
至少有一个字段使用@Id标识主键,多个@Id注解生成联合主键。
@GeneratedValue指定主键生成策略。
Dao层
Dao层使用通用Mapper接口,只需要让我们的接口实现Mapper即可。
此处需注意导入的是tk.mybatis.mapper.common.Mapper而不是mybatis的Mapper
继承该Mapper后,会获取父接口的常用方法。
package com.panda.mapper;
import com.panda.domain.User;
import tk.mybatis.mapper.common.Mapper;
public interface UserDao extends Mapper {
}
业务层
业务层接口:
package com.panda.service;
import com.panda.domain.User;
import java.util.List;
public interface UserService {
User selectOne(String id);
int addOne(User user);
int deleteOne(int id);
int updateOne(User user);
List<User> selectOneNameLike(String name);
List<User> selectAll();
}
业务层实现:
import com.panda.domain.User;
import com.panda.mapper.UserDao;
import com.panda.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import tk.mybatis.mapper.entity.Example;
import java.util.List;
@Service
public class UserServiceImpl implements UserService {
@Autowired
UserDao userDao; //此处如果报错为误报,忽略即可
@Override
public User selectOne(String id) {
return userDao.selectByPrimaryKey(id);
}
@Override
public int addOne(User user) {
return userDao.insertSelective(user);
}
@Override
public int deleteOne(int id) {
return userDao.deleteByPrimaryKey(id);
}
@Override
public int updateOne(User user) {
return userDao.updateByPrimaryKeySelective(user);
}
@Override
public List<User> selectOneNameLike(String name) {
Example example = new Example(User.class);
example.createCriteria().andLike("name","%"+name+"%");
return userDao.selectByExample(example);
}
@Override
public List<User> selectAll() {
return userDao.selectAll();
}
}
通用Mapper的常见方法解析:
基本增删改查
查询
select(T t) :根据传入对象属性查询,返回实体类元素集合。
selectOne(T t)) :根据传入的对象属性查询,存在多个返回值时抛出异常。
selectAll() :返回实体类元素集合。
selectCount(T t)) :根据传入的对象属性查询,返回总记录数。
删除
delete(T t)) 根据传入对象属性,删除所有查找到的记录。
deleteByPrimaryKey(Object key) 根据传入的主键,删除对应记录。
更新
updateByPrimaryKey(Object o) 根据传入对象属性,更新所有字段 。
updateByPrimaryKeySelective(T t) 只更新对象属性非空字段 。
插入
insert(T t)) 根据传入对象属性,插入所有属性对应的字段。
insertSelective(T t)) 根据传入对象属性,只插入对象属性非空字段
复杂条件查询
通用Mapper复杂条件查询使用的是Example,示例语法如下:
Example example = new Example(User.class);
Criteria criteria = example.createCriteria()
criteria.andLike("name","%"+name+"%");
userDao.selectByExample(example);
其中,Criteria对象可使用的方法很多,基本可以满足常用的条件查询:

上面的方法基本从方法名就可以看出其作用,使用起来也比较方便。
显示层
controller实现:
package com.panda.controller;
import com.panda.domain.User;
import com.panda.mapper.UserDao;
import com.panda.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@Controller
public class UserController {
@Autowired
UserService userService;
//增加一个
@RequestMapping("/addOne")
@ResponseBody
public int addOne(){
User user = new User();
user.setName("uzi");
user.setEmail("uzi@rng.com");
return userService.addOne(user);
}
//删除一个
@RequestMapping("/deleteOne")
@ResponseBody
public int deleteOne(int id){
return userService.deleteOne(id);
}
//更新一个
@RequestMapping("/updateOne")
@ResponseBody
public int updateOne(@RequestBody User user){
return userService.updateOne(user);
}
//查询一个
@RequestMapping("/selectOne")
@ResponseBody
public User selectOne(String id){
return userService.selectOne(id);
}
//查询所有
@RequestMapping("/selectAll")
@ResponseBody
public List<User> selectAll(){
return userService.selectAll();
}
//name模糊查询
@RequestMapping("/selectOneNameLike")
@ResponseBody
public List<User> selectOneNameLike(String name){
return userService.selectOneNameLike(name);
}
}
测试
- 测试插入
浏览器输入:[http://localhost:8080/addOne],可以看到数据库成功插入一个,当然正常情况应该是前端请求的 时候传入一个json对象给我们来插入数据 库,这里偷懒使用了自己创建的User对象,不过无伤大雅。 - 测试更新
浏览器输入:[http://localhost:8080/updateOne],通用使用我们自己创建User对象来更新数据库记录。 - 测试查询:[http://localhost:8080/selectOne?id=1],成功查询到id=1的用户
- 测试删除:[http://localhost:8080/deleteOne?id=1],成功删除id=1的用户
通用Mapper的原理简介
通用Mapper通过让dao层接口继承Mapper<T.class> 接口,在运行期通过反射获取实体类T的信息,并构造出对应的SQL,dao层接口只需要直接调用父接口提供的方法,便可完成对应SQL的调用和数据库查询。
更加详细执行过程在此赘述,有感兴趣的朋友可以访问:
[MyBatis 通用 Mapper 实现原理](https://blog.csdn.net/chenyao1994/article/details/79254941
最后
感谢您阅读本文,源码已上传github,欢迎访问:github
通用Mapper使用的更多相关文章
- 【SSM 8】spring集成Mybatis通用Mapper
上篇博客中介绍了关于Mybatis底层封装的思路问题,那么这篇博客,就介绍一下怎么引入通用的mapper插件. 备注:本项目通过maven管理 关键版本说明: spring:4.1.3.RELEASE ...
- 在Spring4中使用通用Mapper
在Spring4中使用通用Mapper http://my.oschina.net/flags/blog/355281#OSC_h2_2 目录[-] 在Spring4中使用通用Mapper 一.在Sp ...
- Spring Boot MyBatis 通用Mapper插件集成
Mybatis在使用过程中需要三个东西,每张表对应一个XXMapper.java接口文件,每张表对应一个XXMapper.xml文件,每张表对应一个Entity的Java文件. 其中XXMappe ...
- 如何使用通用Mapper
集成方法请看上面的文档,集成后,可以继续阅读本页文档. 1. 继承通用的Mapper<T>,必须指定泛型<T> 例如下面的例子: public interface UserIn ...
- 通用mapper的使用
通用mapper的使用 导入依赖 <dependency> <groupId>com.github.abel533</groupId> <artifactId ...
- Mybatis通用Mapper
极其方便的使用Mybatis单表的增删改查 项目地址:http://git.oschina.net/free/Mapper 优点? 不客气的说,使用这个通用Mapper甚至能改变你对Mybatis单表 ...
- tk mybatis通用mapper,复杂and or条件查询
需求:where查询,需要支持(a or b or c) and d 也就是a.b.c三个条件是或的关系,然后再与d相与. 尝试后,可以通过以下方式处理: 方式1:Weekend语法 Weekend& ...
- mybatis通用mapper的使用
项目中持久层封装了两套,一个hibernate,一个是mybatis.hibernate中封装了一些通用的方法,但是mybatis中没有,基于这个需求开始使用mybatis的通用mapper. ...
- 通用mapper认识和用法
目录 0. 认识 1. 导包 2. mybatis的config文件:mybatis-mapper-config.xml 3. spring与mybatis整合配置文件:mybatis.xml 4. ...
- 值得收藏的Mybatis通用Mapper使用大全。
引言 由于小编的记性不太好,每次在写代码的时候总是把通用mapper的方法记错,所以今天把通用mapper的常用方法做一下总结,方便以后直接查看.好了,不废话啦. 引包 <!-- 通用Mappe ...
随机推荐
- VSCode 快速生成 .vue 模版
VSCode 快速生成 .vue 模版 安装vscode 官网:https://code.visualstudio.com/ 安装 Vetur 插件,识别 vue 文件 插件库中搜索Vetur,点击安 ...
- 深入解读ES6系列(一)
ECMAScript 6(ES6)简介 前言: 哈喽小伙伴们,爱说'废'话的Z又回来了,欢迎来到Super IT曾的博客时间,我说啦这个月要带的福利,说了更的博客肯定不能水你们,要一起进步学习嘛,今天 ...
- 实验十一 MySQLl备份与恢复1
实验十一 MySQL备份与恢复 一. 实验内容: 1. 使用SQL语句导入和导出表数据 2. 使用客户端工具备份还原数据库 3. 使用日志文件恢复数据库 二. 实验项目:学生成绩数据库 创建用于学 ...
- 监控一哥Prometheus你可认识?
先大致认识认识普罗米修斯 —— Prometheus. 依据官方文档https://prometheus.io/docs/introduction/overview/ 大概能够了解到 Promethe ...
- Node.js快速创建一个Express应用的几个步骤
Node.js 的 Express 框架学习 转载和参考地址: https://developer.mozilla.org/zh-CN/docs/Learn/Server-side/Express_N ...
- 独立Web站点的快速部署
独立Web站点的快速部署 1案例1:独立Web站点的快速部署 1.1问题 本 ...
- Git-flow 使用笔记
git-flow 原理:A successful Git branching model,两篇不错的中文翻译: Git开发管理之道,一个成功的Git分支模型. 简单来说,git-flow 就是在 gi ...
- 微信小程序分享至朋友圈的方法
最近研究怎么实现微信小程序分享至朋友圈,对就是朋友圈. 微信小程序目前没有直接提供方法来将小程序分享至朋友圈,不过可以采用曲线救国的方式来达到目的. 方法分两步: 1.通过浏览器将希望分享的东西风向至 ...
- C#如何正确的做深拷贝
估计很多人在网上看到各种各样的DeepClone实现, 例如: 1. 通过BinaryFormatter进行二进制序列化 这玩意儿序列化出来的东西还带namespace类型, 尺寸非常大, 调试一下就 ...
- Django ORM操作数据库常用API
昨天晚上,我们完成了一个简单的实例来对数据库表进行操作.今天,我们要熟悉更多的API,实现更复杂的功能.这一步完成了,我们对小型数据的操作问题也就不大了. 现在,我们还是参考django官方文档,来进 ...