真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何在Mybatis-Plus中實現(xiàn)CRUD

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

方山網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項目制作,到程序開發(fā),運營維護(hù)。成都創(chuàng)新互聯(lián)于2013年創(chuàng)立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)。

mybatis-plus也是mybatis的增強(qiáng)版,它并未改變mybatis原有功能,只是在傳統(tǒng)mybatis原有基礎(chǔ)上又新增了一些功能,用以提高開發(fā)效率.

比如,在mybatis-plus框架下,項目mapper層接口可通過繼承BaseMapper,獲取基本的CRUD功能,而無需編寫mapper.xml語句.

AutoGenerator自動生成的mapper.xml如下所示:





  
  
    
    
    
  

  
  
    soldier_id, soldier_name, join_army_time
  

下面的Mapper接口也是自動生成的,里面什么都不用寫:

/**
 * 

 * Mapper 接口  * 

 */ public interface SoldierMapper extends BaseMapper {    }

項目集成mybatis-plus之后,在大多數(shù)CRUD情景下,可以跳過mapper層,直接到業(yè)務(wù)層接口寫接口方法,然后在業(yè)務(wù)實現(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;

/**
 * 

 * 服務(wù)類  * 

 *  * @author gene  * @since 2019-09-11  */ public interface SoldierService extends IService {   /**    * 增加    *     * @param soldier    * @return    */   int insert(Soldier soldier);   /**    * 查詢?nèi)?    *     * @return    */   List selectAll(Wrapper 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); }

實現(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;

/**
 * 

 * 服務(wù)實現(xiàn)類  * 

 *  * @author gene  * @since 2019-09-11  */ @Service public class SoldierServiceImpl extends ServiceImpl implements SoldierService {   @Override   public int insert(Soldier soldier) {     return baseMapper.insert(soldier);   }   @Override   public List selectAll(Wrapper 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.

這是因為druid跟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ù)源:

  
    com.zaxxer
    HikariCP
    3.3.1
  

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


網(wǎng)頁題目:如何在Mybatis-Plus中實現(xiàn)CRUD
文章網(wǎng)址:http://weahome.cn/article/ghdcgo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部