通用Mapper介绍

产生背景

使用Mybatis的开发者大多会因为繁多的XML映射配置而头痛不已,即使使用注解,大量的SQL语句也是不可避免的,当数据库表结构发生变动时,所有对应的sql和实体类都得修改,基于此,通用Mapper出现了

基本概念

通用Mapper是一款用于单表增删改查的Mybatis插件,开发人员可以省去编写sql语句和在DAO层编写任何方法,就能轻松实现单表的常用操作。

项目地址

支持国产,从我做起。通用Mapper的作者是一位国人。项目地址:

环境导入

环境说明

平台:windows
jdk版本:1.8
IDE:IDEA
数据库:mysql(8)

项目创建

  1. 新建一个Springboot项目

    新建项目就没啥好说了,使用IDEA自带的Spring Initializer,一直下一步就完事了,省心

  2. 添加通用mapper依赖

    <dependency>
    <groupId>tk.mybatis</groupId>
    <artifactId>mapper-spring-boot-starter</artifactId>
    <version>2.1.5</version>
    </dependency>
  3. 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

数据准备

  1. 建表语句
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;
}
}

说明

  1. 表名默认使用类名,驼峰会转换为下划线,如UserInfo对应的表名为user_info.当不满足上述对应关系时,类名上使用@Table注解,使用name属性指定tableName;

  2. 类的属性名默认会采用驼峰法转换为表字段名,如userName转化为user_name;不满足上述对应关系时,字段名上使用@Column注解,使用name属性指定表字段名;

  3. 表字段没有的属性,可以使用@Transient注解。

  4. 至少有一个字段使用@Id标识主键,多个@Id注解生成联合主键。

  5. @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的常见方法解析:

  • 基本增删改查

    1. 查询

      select(T t) :根据传入对象属性查询,返回实体类元素集合。

      selectOne(T t)) :根据传入的对象属性查询,存在多个返回值时抛出异常。

      selectAll() :返回实体类元素集合。

      selectCount(T t)) :根据传入的对象属性查询,返回总记录数。

    2. 删除

      delete(T t)) 根据传入对象属性,删除所有查找到的记录。

      deleteByPrimaryKey(Object key) 根据传入的主键,删除对应记录。

    3. 更新

      updateByPrimaryKey(Object o) 根据传入对象属性,更新所有字段 。

      updateByPrimaryKeySelective(T t) 只更新对象属性非空字段 。

    4. 插入

      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);
}
}

测试

  1. 测试插入
    浏览器输入:[http://localhost:8080/addOne],可以看到数据库成功插入一个,当然正常情况应该是前端请求的 时候传入一个json对象给我们来插入数据 库,这里偷懒使用了自己创建的User对象,不过无伤大雅。
  2. 测试更新
    浏览器输入:[http://localhost:8080/updateOne],通用使用我们自己创建User对象来更新数据库记录。
  3. 测试查询:[http://localhost:8080/selectOne?id=1],成功查询到id=1的用户
  4. 测试删除:[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使用的更多相关文章

  1. 【SSM 8】spring集成Mybatis通用Mapper

    上篇博客中介绍了关于Mybatis底层封装的思路问题,那么这篇博客,就介绍一下怎么引入通用的mapper插件. 备注:本项目通过maven管理 关键版本说明: spring:4.1.3.RELEASE ...

  2. 在Spring4中使用通用Mapper

    在Spring4中使用通用Mapper http://my.oschina.net/flags/blog/355281#OSC_h2_2 目录[-] 在Spring4中使用通用Mapper 一.在Sp ...

  3. Spring Boot MyBatis 通用Mapper插件集成

    Mybatis在使用过程中需要三个东西,每张表对应一个XXMapper.java接口文件,每张表对应一个XXMapper.xml文件,每张表对应一个Entity的Java文件.   其中XXMappe ...

  4. 如何使用通用Mapper

    集成方法请看上面的文档,集成后,可以继续阅读本页文档. 1. 继承通用的Mapper<T>,必须指定泛型<T> 例如下面的例子: public interface UserIn ...

  5. 通用mapper的使用

    通用mapper的使用 导入依赖 <dependency> <groupId>com.github.abel533</groupId> <artifactId ...

  6. Mybatis通用Mapper

    极其方便的使用Mybatis单表的增删改查 项目地址:http://git.oschina.net/free/Mapper 优点? 不客气的说,使用这个通用Mapper甚至能改变你对Mybatis单表 ...

  7. tk mybatis通用mapper,复杂and or条件查询

    需求:where查询,需要支持(a or b or c) and d 也就是a.b.c三个条件是或的关系,然后再与d相与. 尝试后,可以通过以下方式处理: 方式1:Weekend语法 Weekend& ...

  8. mybatis通用mapper的使用

    项目中持久层封装了两套,一个hibernate,一个是mybatis.hibernate中封装了一些通用的方法,但是mybatis中没有,基于这个需求开始使用mybatis的通用mapper.     ...

  9. 通用mapper认识和用法

    目录 0. 认识 1. 导包 2. mybatis的config文件:mybatis-mapper-config.xml 3. spring与mybatis整合配置文件:mybatis.xml 4. ...

  10. 值得收藏的Mybatis通用Mapper使用大全。

    引言 由于小编的记性不太好,每次在写代码的时候总是把通用mapper的方法记错,所以今天把通用mapper的常用方法做一下总结,方便以后直接查看.好了,不废话啦. 引包 <!-- 通用Mappe ...

随机推荐

  1. jmeter响应乱码(十四)

    方法一: jmeter响应乱码解决方法:在jmeter的bin目录下找到jmeter.propertis这个文件,修改里面的#sampleresult.default.encoding=ISO-885 ...

  2. python之进程,线程

    什么是进程(process)? 程序并不能单独运行,只有将程序装载到内存中,系统为它分配资源才能运行,而这种执行的程序就称之为进程.程序和进程的区别就在于:程序是指令的集合,它是进程运行的静态描述文本 ...

  3. Fedora20在神州战神K650D1安装过程,使用netinstall和Dvd.iso镜像安装。

    最近新买一笔记本,神州战神K650D-i5 D1.仍旧安装双系统,WIndows7+Fedora20.磁盘分区是这样的: 第一主分区 /boot ext4 20G 第二主分区 / ext4 70G 第 ...

  4. MySQL count知多少

    统计一个表的数据量是经常遇到的需求,但是不同的表设计及不同的写法,统计性能差别会有较大的差异,下面就简单通过实验进行测试(大家测试的时候注意缓存的情况,否则影响测试结果). 1. 准备工作 为了后续测 ...

  5. iOS sign in with Apple 苹果ID登录

    http://www.cocoachina.com/articles/109104?filter=ios https://juejin.im/post/5deefc5e518825126416611d ...

  6. iOS UmbrellaHeader

    Lexical or Preprocessor Issue - Umbrella header for module 'xxx' does not include header 'xxx.h' fra ...

  7. Supervisor 使用和进阶4 (Event 的使用)

    本文主要介绍 supervisor Event 的功能. supervisor 作为一个进程管理工具,在 3.0 版本之后,新增了 Event 的高级特性, 主要用于做(进程启动.退出.失败等)事件告 ...

  8. java应用诊断和在线debug利器bistoury介绍与在K8S环境使用

    Bistoury介绍 Bistoury 是去哪儿网开源的一个对应用透明,无侵入的java应用诊断工具,用于提升开发人员的诊断效率和能力,可以让开发人员无需登录机器或修改系统,就可以从日志.内存.线程. ...

  9. javascript原生 实现数字字母混合验证码

    实现4位数 数字字母混合验证码(数字+大写字母+小写字母) ASCII 字符集中得到3个范围: 1. 48-57 表示数字0-9 2. 65-90 表示大写字母 3. 97-122 表示小写字母 范围 ...

  10. Oracle数据库表和表列讲解

    如果将数据库比作一个存储东西的储物柜,表就像是储物柜上的各个抽屉,每个抽屉分门别类地存放了各种数据,在设计和规划数据库时,表的定义和规划往往相当重要,良好的表设计决定了程序人员编写程序的便利性与数据库 ...