基于Mybatis-Plus的CRUD的實(shí)現(xiàn)
使用mybatis-plus自動(dòng)生成了5個(gè)模塊(xml/bean/mapper/service/controller)的代碼,這里練習(xí)一下mybatis-plus框架下的CRUD.
還是原先的那個(gè)springboot項(xiàng)目.
mybatis-plus也是mybatis的增強(qiáng)版,它并未改變mybatis原有功能,只是在傳統(tǒng)mybatis原有基礎(chǔ)上又新增了一些功能,用以提高開發(fā)效率.
比如,在mybatis-plus框架下,項(xiàng)目mapper層接口可通過繼承BaseMapper,獲取基本的CRUD功能,而無需編寫mapper.xml語句.
AutoGenerator自動(dòng)生成的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">
<!-- 通用查詢映射結(jié)果 -->
<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>
<!-- 通用查詢結(jié)果列 -->
<sql id="Base_Column_List">
soldier_id, soldier_name, join_army_time
</sql>
</mapper>
下面的Mapper接口也是自動(dòng)生成的,里面什么都不用寫:
/**
* <p>
* Mapper 接口
* </p>
*
* @author gene
* @since 2019-09-11
*/
public interface SoldierMapper extends BaseMapper<Soldier> {
}
項(xiàng)目集成mybatis-plus之后,在大多數(shù)CRUD情景下,可以跳過mapper層,直接到業(yè)務(wù)層接口寫接口方法,然后在業(yè)務(wù)實(shí)現(xiàn)類里調(diào)用BaseMapper接口內(nèi)的方法即可.
業(yè)務(wù)接口(要自己動(dòng)手寫了):
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>
* 服務(wù)類
* </p>
*
* @author gene
* @since 2019-09-11
*/
public interface SoldierService extends IService<Soldier> {
/**
* 增加
*
* @param soldier
* @return
*/
int insert(Soldier soldier);
/**
* 查詢?nèi)?
*
* @return
*/
List<Soldier> selectAll(Wrapper<Soldier> queryWrapper);
/**
* 據(jù)ID而查
*
* @param soldier
* @return
*/
Soldier selectById(Integer soldierId);
/**
* 更改1行
*
* @param soldier
* @return
*/
int updateOne(Soldier soldier);
/**
* 刪除一行
*
* @param soldier
* @return
*/
int deleteOne(Soldier soldier);
}
實(shí)現(xiàn)類:
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>
* 服務(wù)實(shí)現(xiàn)類
* </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);
}
}
測試方法,貼一個(gè)"增":
@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逆向工程會將數(shù)據(jù)庫中的date類型轉(zhuǎn)換為LocalDateTime,訪問接口的時(shí)候報(bào)錯(cuò):java.sql.SQLFeatureNotSupportedException.
這是因?yàn)閐ruid跟mybatis3.5.1兼容性問題,mybatis-plus-generator 3.1.2引用了mybatis3.5.1版本,而druid-boot-1.1.18尚未與之兼容,應(yīng)將mybatis-plus版本降至3.1.0或以下即可.
如果上面的法子無效,那就更換druid數(shù)據(jù)源為hikaricp數(shù)據(jù)源:
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
<version>3.3.1</version>
</dependency>
還有一種方法是,把實(shí)體類成員的LocalDateTime類型換為Date類型.
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Mybatis實(shí)現(xiàn)增刪改查(CRUD)實(shí)例代碼
- Mybatis實(shí)現(xiàn)數(shù)據(jù)的增刪改查實(shí)例(CRUD)
- Spring Boot整合Mybatis并完成CRUD操作的實(shí)現(xiàn)示例
- Spring boot整合Mybatis實(shí)現(xiàn)級聯(lián)一對多CRUD操作的完整步驟
- MyBatis Plus配置日志CRUD的使用詳解
- MybatisPlus,無XML分分鐘實(shí)現(xiàn)CRUD操作
- Mybatis-Plus 通用CRUD的詳細(xì)操作
- mybatisplus?復(fù)合主鍵(多主鍵)?CRUD示例詳解
- MyBatis實(shí)現(xiàn)CRUD的示例代碼
相關(guān)文章
Java直接內(nèi)存和堆內(nèi)存的關(guān)系
在Java編程中,內(nèi)存管理是一個(gè)重要的話題,本文介紹了Java中兩種主要內(nèi)存類型:堆內(nèi)存和直接內(nèi)存,堆內(nèi)存是JVM管理的主要內(nèi)存區(qū)域,感興趣的朋友跟隨小編一起看看吧2024-09-09
Servlet實(shí)現(xiàn)統(tǒng)計(jì)頁面訪問次數(shù)功能
這篇文章主要介紹了Servlet實(shí)現(xiàn)統(tǒng)計(jì)頁面訪問次數(shù)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04
SpringMVC框架post提交數(shù)據(jù)庫出現(xiàn)亂碼解決方案
這篇文章主要介紹了SpringMVC框架post提交數(shù)據(jù)庫出現(xiàn)亂碼解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
java實(shí)現(xiàn)最短路徑算法之Dijkstra算法
這篇文章主要介紹了java實(shí)現(xiàn)最短路徑算法之Dijkstra算法, Dijkstra算法是最短路徑算法中為人熟知的一種,是單起點(diǎn)全路徑算法,有興趣的可以了解一下2017-10-10

