溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

基于Mybatis-Plus的CRUD的實(shí)現(xiàn)方式

發(fā)布時(shí)間:2021-09-14 22:37:33 來源:億速云 閱讀:157 作者:chen 欄目:編程語言

這篇文章主要講解了“基于Mybatis-Plus的CRUD的實(shí)現(xiàn)方式”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“基于Mybatis-Plus的CRUD的實(shí)現(xiàn)方式”吧!

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 */@Servicepublic 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);  }}

測(cè)試方法,貼一個(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);  }

收工.

最后是測(cè)試期間遇到的異常:

java.lang.NoSuchMethodError: org.apache.ibatis.session.Configuration.getDefaultScriptingLanguageInstance() Lorg/apache/ibatis/scripting/LanguageDriver      升級(jí)mybatis-spring-boot-starter版本至2.1.0    升級(jí)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

簡(jiǎn)而言之:使用mybatis-plus逆向工程會(huì)將數(shù)據(jù)庫中的date類型轉(zhuǎn)換為L(zhǎng)ocalDateTime,訪問接口的時(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類型.

感謝各位的閱讀,以上就是“基于Mybatis-Plus的CRUD的實(shí)現(xiàn)方式”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)基于Mybatis-Plus的CRUD的實(shí)現(xiàn)方式這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI