如何在Mybatis-Plus中实现CRUD

这篇文章给大家介绍如何在Mybatis-Plus中实现CRUD,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

方山网站制作公司哪家好,找成都创新互联!从网页设计、网站建设、微信开发、APP开发、成都响应式网站建设公司等网站项目制作,到程序开发,运营维护。成都创新互联于2013年创立到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选成都创新互联

mybatis-plus也是mybatis的增强版,它并未改变mybatis原有功能,只是在传统mybatis原有基础上又新增了一些功能,用以提高开发效率.

比如,在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之后,在大多数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;

/**
 * 

 * 服务类  * 

 *  * @author gene  * @since 2019-09-11  */ public interface SoldierService extends IService {   /**    * 增加    *     * @param soldier    * @return    */   int insert(Soldier soldier);   /**    * 查询全部    *     * @return    */   List selectAll(Wrapper 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;

/**
 * 

 * 服务实现类  * 

 *  * @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逆向工程会将数据库中的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数据源:

  
    com.zaxxer
    HikariCP
    3.3.1
  

关于如何在Mybatis-Plus中实现CRUD就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


当前标题:如何在Mybatis-Plus中实现CRUD
链接分享:http://scyanting.com/article/ghdcgo.html