基于Mybatis-Plus的CRUD的實(shí)現(xiàn)
使用mybatis-plus自動生成了5個模塊(xml/bean/mapper/service/controller)的代碼,這里練習(xí)一下mybatis-plus框架下的CRUD.
還是原先的那個springboot項(xiàng)目.
mybatis-plus也是mybatis的增強(qiáng)版,它并未改變mybatis原有功能,只是在傳統(tǒng)mybatis原有基礎(chǔ)上又新增了一些功能,用以提高開發(fā)效率.
比如,在mybatis-plus框架下,項(xiàng)目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"> <!-- 通用查詢映射結(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接口也是自動生成的,里面什么都不用寫:
/** * <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ù)接口(要自己動手寫了):
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); } }
測試方法,貼一個"增":
@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,訪問接口的時候報錯: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)文章
Spring中TransactionSynchronizationManager的使用詳解
這篇文章主要介紹了Spring中TransactionSynchronizationManager的使用詳解,TransactionSynchronizationManager是事務(wù)同步管理器,監(jiān)聽事務(wù)的操作,來實(shí)現(xiàn)在事務(wù)前后可以添加一些指定操作,需要的朋友可以參考下2023-09-09單點(diǎn)登錄的概念及SpringBoot實(shí)現(xiàn)單點(diǎn)登錄的操作方法
在本文中,我們將使用Spring Boot構(gòu)建一個基本的單點(diǎn)登錄系統(tǒng),我們將介紹如何使用Spring Security和JSON Web Tokens(JWTs)來實(shí)現(xiàn)單點(diǎn)登錄功能,本文假設(shè)您已經(jīng)熟悉Spring Boot和Spring Security,感興趣的朋友一起看看吧2024-10-10springboot中實(shí)現(xiàn)上傳文件的功能簡單示例
這篇文章主要給大家介紹了關(guān)于springboot中實(shí)現(xiàn)上傳文件功能的相關(guān)資料,在Spring Boot中實(shí)現(xiàn)文件上傳下載功能相對簡單,文中給出了代碼示例,需要的朋友可以參考下2023-09-09?Java圖形化界面編程實(shí)現(xiàn)簡單計(jì)算器
這篇文章主要介紹了Java圖形化界面編程實(shí)現(xiàn)簡單計(jì)算器,下面文章圍繞Java圖形化界面編程實(shí)現(xiàn)簡單計(jì)算器的相關(guān)資料展開詳細(xì)內(nèi)容,具有一定的參考價值,需要的小伙伴可以參考一下2022-01-01Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(47)
下面小編就為大家?guī)硪黄狫ava基礎(chǔ)的幾道練習(xí)題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你2021-08-08Java數(shù)據(jù)結(jié)構(gòu)學(xué)習(xí)之樹
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)學(xué)習(xí)之樹,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java數(shù)據(jù)結(jié)構(gòu)的小伙伴們有非常好的幫助,需要的朋友可以參考下2021-05-05