乐趣区

基于MybatisPlus的CRUD

使用 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 类型.


退出移动版