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

方山網站制作公司哪家好,找成都創新互聯!從網頁設計、網站建設、微信開發、APP開發、成都響應式網站建設公司等網站項目制作,到程序開發,運營維護。成都創新互聯于2013年創立到現在10年的時間,我們擁有了豐富的建站經驗和運維經驗,來保證我們的工作的順利進行。專注于網站建設就選成都創新互聯。
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就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
網頁名稱:如何在Mybatis-Plus中實現CRUD
URL鏈接:http://www.yijiale78.com/article10/ghdcgo.html
成都網站建設公司_創新互聯,為您提供網站改版、靜態網站、定制網站、品牌網站設計、虛擬主機、響應式網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯