91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在Mybatis-Plus中實現CRUD

發布時間:2021-05-27 18:13:06 來源:億速云 閱讀:196 作者:Leah 欄目:編程語言

這篇文章給大家介紹如何在Mybatis-Plus中實現CRUD,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

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>

 */
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>

關于如何在Mybatis-Plus中實現CRUD就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

高平市| 临江市| 都昌县| 临夏县| 西贡区| 榆中县| 永宁县| 罗山县| 长春市| 荃湾区| 天长市| 宜章县| 股票| 赣榆县| 阿瓦提县| 罗平县| 大港区| 常熟市| 霞浦县| 湖北省| 濮阳县| 宁远县| 洪雅县| 旺苍县| 高州市| 远安县| 连城县| 襄垣县| 盘锦市| 成安县| 达州市| 浠水县| 宝清县| 章丘市| 仙游县| 南阳市| 洛宁县| 塘沽区| 隆子县| 漳浦县| 克拉玛依市|