基于Mybatis-Plus的CRUD的实现
作者:DEFAULT 发布时间:2023-09-10 14:38:45
使用mybatis-plus自动生成了5个模块(xml/bean/mapper/service/controller)的代码,这里练习一下mybatis-plus框架下的CRUD.
还是原先的那个springboot项目.
mybatis-plus也是mybatis的增强版,它并未改变mybatis原有功能,只是在传统mybatis原有基础上又新增了一些功能,用以提高开发效率.
比如,在mybatis-plus框架下,项目mapper层接口可通过继承BaseMapper,获取基本的CRUD功能,而无需编写mapper.xml语句.
AutoGenerator自动生成的mapper.xml如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://www.mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<mapper namespace="cn.example.demo.mapper.SoldierMapper">
<!-- 通用查询映射结果 -->
<resultMap id="BaseResultMap" type="cn.example.demo.bean.Soldier">
<id column="soldier_id" property="soldierId" />
<result column="soldier_name" property="soldierName" />
<result column="join_army_time" property="joinArmyTime" />
</resultMap>
<!-- 通用查询结果列 -->
<sql id="Base_Column_List">
soldier_id, soldier_name, join_army_time
</sql>
</mapper>
下面的Mapper接口也是自动生成的,里面什么都不用写:
/**
* <p>
* Mapper 接口
* </p>
*
* @author gene
* @since 2019-09-11
*/
public interface SoldierMapper extends BaseMapper<Soldier> {
}
项目集成mybatis-plus之后,在大多数CRUD情景下,可以跳过mapper层,直接到业务层接口写接口方法,然后在业务实现类里调用BaseMapper接口内的方法即可.
业务接口(要自己动手写了):
package cn.example.demo.service;
import java.util.List;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.IService;
import cn.example.demo.bean.Soldier;
/**
* <p>
* 服务类
* </p>
*
* @author gene
* @since 2019-09-11
*/
public interface SoldierService extends IService<Soldier> {
/**
* 增加
*
* @param soldier
* @return
*/
int insert(Soldier soldier);
/**
* 查询全部
*
* @return
*/
List<Soldier> selectAll(Wrapper<Soldier> queryWrapper);
/**
* 据ID而查
*
* @param soldier
* @return
*/
Soldier selectById(Integer soldierId);
/**
* 更改1行
*
* @param soldier
* @return
*/
int updateOne(Soldier soldier);
/**
* 删除一行
*
* @param soldier
* @return
*/
int deleteOne(Soldier soldier);
}
实现类:
package cn.example.demo.service.impl;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import cn.example.demo.bean.Soldier;
import cn.example.demo.mapper.SoldierMapper;
import cn.example.demo.service.SoldierService;
import java.util.List;
import org.springframework.stereotype.Service;
/**
* <p>
* 服务实现类
* </p>
*
* @author gene
* @since 2019-09-11
*/
@Service
public class SoldierServiceImpl extends ServiceImpl<SoldierMapper, Soldier> implements SoldierService {
@Override
public int insert(Soldier soldier) {
return baseMapper.insert(soldier);
}
@Override
public List<Soldier> selectAll(Wrapper<Soldier> queryWrapper) {
return baseMapper.selectList(queryWrapper);
}
@Override
public Soldier selectById(Integer soldierId) {
return baseMapper.selectById(soldierId);
}
@Override
public int updateOne(Soldier soldier) {
return baseMapper.updateById(soldier);
}
@Override
public int deleteOne(Soldier soldier) {
return baseMapper.deleteById(soldier);
}
}
测试方法,贴一个"增":
@Autowired
private SoldierService ss;
@Test
public void insertTest() {
LocalDateTime now = LocalDateTime.now();
Soldier soldier = new Soldier("yaobuqi", now);
int affect = ss.insert(soldier);
System.err.println("affect- " + affect);
}
收工.
最后是测试期间遇到的异常:
java.lang.NoSuchMethodError: org.apache.ibatis.session.Configuration.getDefaultScriptingLanguageInstance() Lorg/apache/ibatis/scripting/LanguageDriver
升级mybatis-spring-boot-starter版本至2.1.0
升级mybatis-generator-core版本至1.3.7
dao.InvalidDataAccessApiUsageException: Error attempting to get column 'join_army_time' from result set. Cause: java.sql.SQLFeatureNotSupportedException; null; nested exception is java.sql.SQLFeatureNotSupportedException
简而言之:使用mybatis-plus逆向工程会将数据库中的date类型转换为LocalDateTime,访问接口的时候报错:java.sql.SQLFeatureNotSupportedException.
这是因为druid跟mybatis3.5.1兼容性问题,mybatis-plus-generator 3.1.2引用了mybatis3.5.1版本,而druid-boot-1.1.18尚未与之兼容,应将mybatis-plus版本降至3.1.0或以下即可.
如果上面的法子无效,那就更换druid数据源为hikaricp数据源:
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
<version>3.3.1</version>
</dependency>
还有一种方法是,把实体类成员的LocalDateTime类型换为Date类型.
来源:https://segmentfault.com/a/1190000020958698


猜你喜欢
- 做快递面单打印模板,快递要求纸张大小100 x 150mm。PageSize.A4=595 x 842A4尺寸=210mm×297mm故设置
- 目录引言配置yml文件创建数据源配置类为每个数据库创建配置类引言今天为大家带来一些非常有用的实战技巧,比如在我们需要对两个数据库进行操作的时
- Spring底层核心原理下面这几行代码是一个Spring的入门代码,第一行是通过java配置类 注解的方式创建一个Spring容器,第二行是
- 在学习MyBatis过程中想实现模糊查询,可惜失败了。后来上百度上查了一下,算是解决了。记录一下MyBatis实现模糊查询的几种方式。 数据
- 这篇文章主要介绍了springboot实现文件上传步骤解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要
- 参考了一下网上别人写的,再使用的时候是放在新开的线程中来播放音乐的,后来发现每次进入Activity后就会重复开始一个音乐播放的声音。为了避
- 在线程中有两种常用的方法,能够通过数组实现相应的功能,但除此之外在区别上也是很明显的。本篇就其中的代表方法ArrayList和Vector进
- 在Android实现没有标题栏的方法有两种:在代码中添加requestWindowFeature(Window.FEATURE_NO_TIT
- static :静态常量,静态方法,静态代码块静态变量: 静态变量属于类的,使用类名来访问,非静态变量是属于对象的,"必须&quo
- 一、版本说明spring3.1以下的版本必须使用quartz1.x系列,3.1以上的版本才支持quartz 2.x,不然会出错。原因:spr
- 1.@RequestMapping注解1.1@RequestMapping注解的功能从注解名称上我们可以看到,@RequestMapping
- Android 自定义dialog的实现代码搜索相关关键字网上一大堆实现,但是看完总觉得缺胳膊少腿,绕了不少弯路,终于弄好了自定义dialo
- 前言去年7月时,在Github发布了一个开源的Banner库,虽然Star不多,但还是有少部分人使用。Banner效果:Github链接地址
- 1.@GrpcServise的作用和优势在没有使用@GrpcServise注解编写服务端时,我们通常需要自定义Server以及端口,包括st
- 废话不多说了,直接给大家贴代码了,具体代码如下所示:private SystemBarTintManager tintManager;@Ov
- 前言笔者因为项目需要自定义相机,所以了解了一下 Android 关于 camera 这块的 API。Android SDK 21(LOLLI
- 这一篇,给大家介绍一下ImageView控件的使用,ImageView主要是用来显示图片,可以对图片进行放大、缩小、旋转的功能。androi
- 说明本文主要配置Jackson对Long、Date、LocalDate、LocalDateTime的序列化和反序列化。由于js中整数可精确表
- 在项目中我们肯定不能使用Spring自己生成的登录页面,而要用我们自己的登录页面,下面讲一下如何自定义登录页面,先看下配置<sec:h
- C# 的类型系统可分为两种类型,一是值类型,一是引用类型,这个每个C#程序员都了解。还有托管堆,栈,ref,out等等概念也是每个C#程序员