1、如何使用BaseMapper进行数据库的操作。

2、使用BaseMapper进行插入实体时如何让UUID的主键自动生成。

Student实体类,其中id属性主键为UUID

package com.huixiaoer.ant.api.model.bean;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId; public class Student {
/**
*
* This field was generated by MyBatis Generator.
* This field corresponds to the database column student.id
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
@TableId(type= IdType.UUID)
private String id; /**
*
* This field was generated by MyBatis Generator.
* This field corresponds to the database column student.user_name
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
private String userName; /**
*
* This field was generated by MyBatis Generator.
* This field corresponds to the database column student.age
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
private Integer age; /**
*
* This field was generated by MyBatis Generator.
* This field corresponds to the database column student.phone
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
private String phone; /**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table student
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public Student(String id, String userName, Integer age, String phone) {
this.id = id;
this.userName = userName;
this.age = age;
this.phone = phone;
} /**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table student
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public Student() {
super();
} /**
* This method was generated by MyBatis Generator.
* This method returns the value of the database column student.id
*
* @return the value of student.id
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public String getId() {
return id;
} /**
* This method was generated by MyBatis Generator.
* This method sets the value of the database column student.id
*
* @param id the value for student.id
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public void setId(String id) {
this.id = id == null ? null : id.trim();
} /**
* This method was generated by MyBatis Generator.
* This method returns the value of the database column student.user_name
*
* @return the value of student.user_name
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public String getUserName() {
return userName;
} /**
* This method was generated by MyBatis Generator.
* This method sets the value of the database column student.user_name
*
* @param userName the value for student.user_name
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public void setUserName(String userName) {
this.userName = userName == null ? null : userName.trim();
} /**
* This method was generated by MyBatis Generator.
* This method returns the value of the database column student.age
*
* @return the value of student.age
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public Integer getAge() {
return age;
} /**
* This method was generated by MyBatis Generator.
* This method sets the value of the database column student.age
*
* @param age the value for student.age
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public void setAge(Integer age) {
this.age = age;
} /**
* This method was generated by MyBatis Generator.
* This method returns the value of the database column student.phone
*
* @return the value of student.phone
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public String getPhone() {
return phone;
} /**
* This method was generated by MyBatis Generator.
* This method sets the value of the database column student.phone
*
* @param phone the value for student.phone
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
public void setPhone(String phone) {
this.phone = phone == null ? null : phone.trim();
}
}

StudnetVI实体类,用户从页面接收参数

package com.huixiaoer.ant.api.model.vi;

import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty; @ApiModel(value = "student对象",description = "学生对象student")
public class StudentVI { /**
*
* This field was generated by MyBatis Generator.
* This field corresponds to the database column student.user_name
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
@ApiModelProperty(value="学生姓名",name="userName",required=true)
private String userName; /**
*
* This field was generated by MyBatis Generator.
* This field corresponds to the database column student.age
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
@ApiModelProperty(value="年龄",name="age",required=true)
private Integer age; /**
*
* This field was generated by MyBatis Generator.
* This field corresponds to the database column student.phone
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
@ApiModelProperty(value="手机号",name="phone",required=true)
private String phone; public String getUserName() {
return userName;
} public void setUserName(String userName) {
this.userName = userName;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
} public String getPhone() {
return phone;
} public void setPhone(String phone) {
this.phone = phone;
} }

StudentPlusMapper接口类,实现BaseMapper用来实现Mybatis-Plus的增强功能。

package com.huixiaoer.ant.api.repository.mysql.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.huixiaoer.ant.api.model.bean.Student; public interface StudentPlusMapper extends BaseMapper<Student> {
//不需要实现,这时候就可以调用baseMapper的增删改查了
}

StudentService业务接口类

package com.huixiaoer.ant.api.service;

import com.huixiaoer.ant.api.model.bean.Student;
import com.huixiaoer.ant.api.model.bean.StudentExample;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.SelectKey; import java.util.List; public interface StudentService {
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table student
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
long countByExample(StudentExample example); /**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table student
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
int deleteByExample(StudentExample example); /**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table student
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
@Insert({
"insert into student (id, user_name, ",
"age, phone)",
"values (#{id,jdbcType=VARCHAR}, #{userName,jdbcType=VARCHAR}, ",
"#{age,jdbcType=INTEGER}, #{phone,jdbcType=VARCHAR})"
})
@SelectKey(statement="select uuid_short()", keyProperty="id", before=true, resultType=String.class)
int insert(Student record); /**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table student
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
int insertSelective(Student record); /**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table student
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
List<Student> selectByExample(StudentExample example); /**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table student
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
int updateByExampleSelective(@Param("record") Student record, @Param("example") StudentExample example); /**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table student
*
* @mbg.generated Thu Oct 31 14:09:39 CST 2019
*/
int updateByExample(@Param("record") Student record, @Param("example") StudentExample example);
}

StudentServiceImpl业务接口实现类,这里将mybatis-plus的mapper接口注入其中。

package com.huixiaoer.ant.api.service.impl;

import com.huixiaoer.ant.api.model.bean.Student;
import com.huixiaoer.ant.api.model.bean.StudentExample;
import com.huixiaoer.ant.api.repository.mysql.mapper.StudentMapper;
import com.huixiaoer.ant.api.repository.mysql.mapper.StudentPlusMapper;
import com.huixiaoer.ant.api.service.StudentService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import java.util.List; @Service
@Slf4j
public class StudentServiceImpl implements StudentService { @Autowired
private StudentMapper studentMapper; @Autowired
private StudentPlusMapper studentPlusMapper; @Override
public long countByExample(StudentExample example) {
return 0;
} @Override
public int deleteByExample(StudentExample example) {
return 0;
} @Override
public int insert(Student record) {
return studentPlusMapper.insert(record);
} @Override
public int insertSelective(Student record) {
return studentMapper.insertSelective(record);
} @Override
public List<Student> selectByExample(StudentExample example) {
return null;
} @Override
public int updateByExampleSelective(Student record, StudentExample example) {
return 0;
} @Override
public int updateByExample(Student record, StudentExample example) {
return 0;
}
}

SchoolController类,实现前端和后台的交互。自动注入学生业务实现类。

package com.huixiaoer.ant.api.controller;

import com.huixiaoer.ant.api.common.constant.ResultCode;
import com.huixiaoer.ant.api.model.bean.Student;
import com.huixiaoer.ant.api.model.vi.StudentVI;
import com.huixiaoer.ant.api.service.impl.StudentServiceImpl;
import com.huixiaoer.ant.api.util.*;
import io.swagger.annotations.*;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.UUID; /**
* @author create by yiqiang.wu
* @create 2019/06/12
* @email yiqiang.wu@huixiaoer.com
* @description 登录
*/
@Slf4j
@RestController
@Api(tags = "学校 相关接口")
public class SchoolController { @Autowired
private StudentServiceImpl studentService; @Autowired
private HttpServletRequest request; @ApiOperation(value = "增加学生信息")
@PostMapping(value = "/insert/student")
public CommonResult insertStudent(@RequestBody @ApiParam(name="学生对象",value="传入json格式",required=true) StudentVI studentVI) {
try {
Student student = new Student();
// student.setId(UUID.randomUUID().toString());
student.setUserName(studentVI.getUserName());
student.setAge(studentVI.getAge());
student.setPhone(studentVI.getPhone());
studentService.insert(student);
} catch (Exception e) {
System.out.println(e);
return CommonUtil.buildResponse(ResultCode.SYSTEM_ERROR, ResultCode.SYSTEM_ERROR_MSG);
}
return CommonUtil.buildResponse(ResultCode.SUCCESS, ResultCode.SUCCESS_MSG);
} }

补充一下Mybatis的xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.huixiaoer.ant.api.repository.mysql.mapper.StudentMapper">
<resultMap id="BaseResultMap" type="com.huixiaoer.ant.api.model.bean.Student">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
<constructor>
<arg column="id" javaType="java.lang.String" jdbcType="VARCHAR" />
<arg column="user_name" javaType="java.lang.String" jdbcType="VARCHAR" />
<arg column="age" javaType="java.lang.Integer" jdbcType="INTEGER" />
<arg column="phone" javaType="java.lang.String" jdbcType="VARCHAR" />
</constructor>
</resultMap>
<sql id="Example_Where_Clause">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
<where>
<foreach collection="oredCriteria" item="criteria" separator="or">
<if test="criteria.valid">
<trim prefix="(" prefixOverrides="and" suffix=")">
<foreach collection="criteria.criteria" item="criterion">
<choose>
<when test="criterion.noValue">
and ${criterion.condition}
</when>
<when test="criterion.singleValue">
and ${criterion.condition} #{criterion.value}
</when>
<when test="criterion.betweenValue">
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
</when>
<when test="criterion.listValue">
and ${criterion.condition}
<foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
#{listItem}
</foreach>
</when>
</choose>
</foreach>
</trim>
</if>
</foreach>
</where>
</sql>
<sql id="Update_By_Example_Where_Clause">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
<where>
<foreach collection="example.oredCriteria" item="criteria" separator="or">
<if test="criteria.valid">
<trim prefix="(" prefixOverrides="and" suffix=")">
<foreach collection="criteria.criteria" item="criterion">
<choose>
<when test="criterion.noValue">
and ${criterion.condition}
</when>
<when test="criterion.singleValue">
and ${criterion.condition} #{criterion.value}
</when>
<when test="criterion.betweenValue">
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
</when>
<when test="criterion.listValue">
and ${criterion.condition}
<foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
#{listItem}
</foreach>
</when>
</choose>
</foreach>
</trim>
</if>
</foreach>
</where>
</sql>
<sql id="Base_Column_List">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
id, user_name, age, phone
</sql>
<select id="selectByExample" parameterType="com.huixiaoer.ant.api.model.bean.StudentExample" resultMap="BaseResultMap">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
select
<if test="distinct">
distinct
</if>
<include refid="Base_Column_List" />
from student
<if test="_parameter != null">
<include refid="Example_Where_Clause" />
</if>
<if test="orderByClause != null">
order by ${orderByClause}
</if>
</select>
<delete id="deleteByExample" parameterType="com.huixiaoer.ant.api.model.bean.StudentExample">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
delete from student
<if test="_parameter != null">
<include refid="Example_Where_Clause" />
</if>
</delete>
<insert id="insertSelective" parameterType="com.huixiaoer.ant.api.model.bean.Student">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
<selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String">
select uuid_short()
</selectKey>
insert into student
<trim prefix="(" suffix=")" suffixOverrides=",">
id,
<if test="userName != null">
user_name,
</if>
<if test="age != null">
age,
</if>
<if test="phone != null">
phone,
</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
#{id,jdbcType=VARCHAR},
<if test="userName != null">
#{userName,jdbcType=VARCHAR},
</if>
<if test="age != null">
#{age,jdbcType=INTEGER},
</if>
<if test="phone != null">
#{phone,jdbcType=VARCHAR},
</if>
</trim>
</insert>
<select id="countByExample" parameterType="com.huixiaoer.ant.api.model.bean.StudentExample" resultType="java.lang.Long">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
select count(*) from student
<if test="_parameter != null">
<include refid="Example_Where_Clause" />
</if>
</select>
<update id="updateByExampleSelective" parameterType="map">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
update student
<set>
<if test="record.id != null">
id = #{record.id,jdbcType=VARCHAR},
</if>
<if test="record.userName != null">
user_name = #{record.userName,jdbcType=VARCHAR},
</if>
<if test="record.age != null">
age = #{record.age,jdbcType=INTEGER},
</if>
<if test="record.phone != null">
phone = #{record.phone,jdbcType=VARCHAR},
</if>
</set>
<if test="_parameter != null">
<include refid="Update_By_Example_Where_Clause" />
</if>
</update>
<update id="updateByExample" parameterType="map">
<!--
WARNING - @mbg.generated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 31 14:09:39 CST 2019.
-->
update student
set id = #{record.id,jdbcType=VARCHAR},
user_name = #{record.userName,jdbcType=VARCHAR},
age = #{record.age,jdbcType=INTEGER},
phone = #{record.phone,jdbcType=VARCHAR}
<if test="_parameter != null">
<include refid="Update_By_Example_Where_Clause" />
</if>
</update>
</mapper>

各种UUID生成策略,生成的UUID值进行比较。

Mybatis-Plus的BaseMapper的用法的更多相关文章

  1. 9.mybatis动态SQL标签的用法

    mybatis动态SQL标签的用法   动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么 ...

  2. MyBatis从入门到精通(2):MyBatis XML方式的基本用法

    本章将通过完成权限管理的常见业务来学习 MyBatis XML方式的基本用法 2.1一个简单的权限控制需求 权限管理的需求: 一个用户拥有若干角色,一个角色拥有若干权限,权限就是对某个模块资源的某种操 ...

  3. MyBatis #{} 和 ${} 引用值的用法

    1.#{} 引用值的用法 UserMapper配置文件: <select id="queryOne" resultType="cn.tedu.mybatis.bea ...

  4. MyBatis从入门到精通(二):MyBatis XML方式的基本用法之Select

    最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. 明确需求 书中提到的需求是一个基 ...

  5. MyBatis从入门到精通(三):MyBatis XML方式的基本用法之多表查询

    最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. 多表查询 上篇博客中,我们示例的 ...

  6. MyBatis从入门到精通(四):MyBatis XML方式的基本用法之增删改

    最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. insert用法 1.1 简单的 ...

  7. MyBatis:choose标签的用法

    <!-- 4.2 choose用法 需求: 在已有的sys_user表中,除了主键id外,我们认为user_name也是唯一的, 所有的用户名都不可以重复.现在进行如下查询:当参数id有值的时候 ...

  8. MyBatis中foreach循环的用法

    一.在了解foreach之前,先了解一下mybatis传入参数及parameterType 1.我们在Dao层向对应的mapper.xml文件传递参数时,可以传递的参数有: ①.基本数据类型(如int ...

  9. MyBatis从入门到精通(第2章):MyBatis XML方式的基本用法【insert用法、update用法、delete用法】

    2.4  insert 用法 2.4.1  简单的 insert方法 在接口 UserMapper.java 中添加如下方法. /** * 新增用户 * @param sysUser * @retur ...

随机推荐

  1. PTA(Basic Level)1036.跟奥巴马一起编程

    美国总统奥巴马不仅呼吁所有人都学习编程,甚至以身作则编写代码,成为美国历史上首位编写计算机代码的总统.2014 年底,为庆祝"计算机科学教育周"正式启动,奥巴马编写了很简单的计算机 ...

  2. Microsoft SQL server 2012数据库学习总结(一)

    一.Microsoft SQL Server2012简介 1.基本概要 Microsoft SQL Server 2012是微软发布的新一代数据平台产品,全面支持云技术与平台,并且能够快速构建相应的解 ...

  3. 阿里云对象存储OSS

    阿里云的产品种类繁多,今天让我们一起来了解下对象存储(Object Storage Service,简称OSS)吧! 什么是对象存储呢? 简单来说,对象存储OSS是阿里云提供的海量.安全和高可靠的云存 ...

  4. [LGP4859,...] 一类奇怪的容斥套DP

    漫山遍野都是fake的光影. 题目 [LGP4859] 已经没有什么好害怕的了 给定两个长度为n的数组a和b,将a中元素与b中元素配对,求满足ai>bj的配对(i,j)个数减去满足ai<b ...

  5. Django发送邮件和itsdangerous模块的配合使用

    项目需求:用户注册页面注册之后,系统会发送一封邮件到用户邮箱,用户点击链接以激活账户,其中链接中的用户信息需要加密处理一下 其中激活自己邮箱的smtp服务的操作就不在加以说明,菜鸟教程上有非常清晰的讲 ...

  6. Java设计模式之外观模式和最少知识原则

    外观模式: 外观模式:提供一个统一的接口,来访问子系统中一群功能相关接口(类似一键启动,一键关闭等等) 外观模式定义了一个高层接口,让子系统更容易使用 降低对外接口耦合度 外观模式和命令模式各自侧重点 ...

  7. 2019年8月22日 星期四(怎样成为PHP大牛)

    1.服务器方面,各种PHP部署方案烂熟,Lvs,keepalived,nginx,apache,docker,换句话说其战力值相当于一个高级运维,迅速定位并排除PHP运行中的各种问题. 2.数据库方面 ...

  8. jmeter 获取图形验证码接口测试

    今天开发提测了一个图形验证码的接口,以前没有测过这个,上来有点懵..... 记录一下. 使用jmeter配置好接口和参数,运行后查看结果树,显示都是乱码 解决方法: 添加一个后置处理器--beansh ...

  9. postman 获取登录成功后存在在header中cookies,并在下一个接口中使用。

    1.首先登录成功 2.在tests中添加脚本 3.添加环境变量 4.配置环境变量和引用值 5.请求第二个接口成功

  10. 给Repater增加等号

    //不改变数据结构的情况下,增加行号.对Application服务器压力增大,减少DB服务器压力.    protected void repShow_ItemDataBound(object sen ...