如何使用MyBatis Plus實現(xiàn)數(shù)據(jù)庫curd操作
MyBatis-Plus實現(xiàn)數(shù)據(jù)庫curd操作
1.mp是什么
- MyBatis-Plus(簡稱MP)是一個MyBatis 的增強(qiáng)工具,在MyBatis,的基礎(chǔ)上只做增強(qiáng)不做改變,為簡化開發(fā)、提高效率而生。
- 潤物無聲,
- 只做增強(qiáng)不做改變,引入它不會對現(xiàn)有工程產(chǎn)生影響,如絲般順滑。
- 效率至上,
- 只需簡單配置,即可快速進(jìn)行CRUD操作,從而節(jié)省大量時間。
- 豐富功能
- 熱加載、代碼生成、分頁、性能分析等功能一應(yīng)俱全。
mp實現(xiàn)添加修改刪除查詢
mp自動填充樂觀鎖
mp邏輯刪除
mp分頁查詢
2、mp入門
CREATE TABLE `user` ( `id` bigint NOT NULL COMMENT '主鍵ID', `name` varchar(30) DEFAULT NULL COMMENT '姓名', `age` int DEFAULT NULL COMMENT '年齡', `email` varchar(50) DEFAULT NULL COMMENT '郵箱', PRIMARY KEY (`id`) ) INSERT INTO `user`(`id`,`name`,`age`,`email`) VALUES (1,'Jone',18,'test1@baomidou.com'), (2,'Jack',20,'test2@baomidou.com'), (3,'Tom',28,'test3@baomidou.com'), (4,'Sandy',21,'test4@baomidou.com'), (5,'Billie',24,'test5@baomidou.com');
sprinboot版本 2. 2.1

引入相關(guān)依賴
<!--mp-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.2</version>
</dependency>
<!--mysql-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
下載好lombok插件
配置數(shù)據(jù)庫信息
創(chuàng)建實體類User
創(chuàng)建對應(yīng)的Mapper
繼承BaseMapper,里面封裝了常用的增刪查改方法
在啟動類上增加掃描該mapper的路徑。因為是該接口動態(tài)生成的,默認(rèn)掃描不到、
@Autowired 對類成員變量、方法及構(gòu)造函數(shù)進(jìn)行標(biāo)注,完成自動裝配的工作。
通過 @Autowired的使用來消除 set ,get方法
@Repository、@Service、@Controller 和 @Component 將類標(biāo)識為Bean
@Repository(“名稱”):dao層
@Service(“名稱”):service層
@Controller(“名稱”):web層
#mybatis日志 開啟 mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
MP主鍵策略

ASSIGN_ID默認(rèn)生成19位 (根據(jù)符號位,時間戳、、、等等生成,百度)auto:自動增長
默認(rèn)開啟ASSIGN_ID
#全局設(shè)置主鍵生成策略
mybatis-plus.global-config.db-config.id-type=auto
2.1、curd
查找
void findAll() {
List<User> users = userMapper.selectList(null);
users.forEach(System.out::println);
}
增加
void addUser(){
User user = new User(12L, "黎明", 23, "592923@qq.com");
int insert = userMapper.insert(user); //影響行數(shù)
System.out.println(insert);
}
修改
public void upData(){
User user = new User();
user.setId(12L);
user.setName("hhha");
int i = userMapper.updateById(user);
System.out.println("影響行數(shù)"+i);
}
2.2、自動填充
字段賦值的時候需要set
增加兩個字段,對應(yīng)的實體類也增加
@TableField(fill = FieldFill.INSERT) private Data createTime; @TableField(fill = FieldFill.INSERT_UPDATE) private Data updateTime;
新建一個類不要忘記添加注解將它交給Spring管理
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
//實現(xiàn)兩個方法,自動填充增加、修改
}
3、樂觀鎖
3.1、場景
主要適用場景:當(dāng)要更新一條記錄的時候,希望這條記錄沒有被別人更新,也就是說實現(xiàn)線程安全的數(shù)據(jù)更新
解決丟失更新的問題。(可重復(fù)讀,解決了不可重復(fù)讀,隔離性第三級別,Mysql默認(rèn))
樂觀鎖實現(xiàn)方式:
取出記錄時,獲取當(dāng)前versione更新時,帶上這個versionv
執(zhí)行更新時,set version = newexsion where version = oldVersion
如果version不對,就更新失敗
提交后修改版本號,另一個提交時,會先檢查版本號和獲取時是否一樣,不一樣提交失敗,一樣提交成功。
MP實現(xiàn)樂觀鎖。
1.顯然,需要在表中加上字段version,實體類也是
添加注解@Version即可
3.配置樂觀鎖插件,Spring Boot創(chuàng)建一個配置類
添加配置注解,添加掃描,創(chuàng)建一個樂觀鎖插件
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
4、MP查詢
4.1、多個ID批量查詢
selectBatchIds():Batch 批量
@Test
public void select1() {
List<User> users = userMapper.selectBatchIds(Arrays.asList(1, 2, 3));
for (User user : users) {
System.out.println(user);
}
}
4.2、簡單條件查詢(Map)
public void select2(){
Map<String, Object> columnMap = new HashMap<>();
columnMap.put("name", "Jack");
columnMap.put("age", "20");
List<User> users = userMapper.selectByMap(columnMap);
System.out.println(users);
}
value的屬性 不對應(yīng)數(shù)據(jù)庫中的也能查詢到
4.3、分頁查詢
邏輯

public void selectPage() {
Page<User> page = new Page<>(1,3);
Page<User> userPage = userMapper.selectPage(page,null);
long pages = userPage.getPages();//總頁數(shù)
long current = userPage.getCurrent();//當(dāng)前頁
List<User> records = userPage.getRecords();//數(shù)據(jù)集合
long total = userPage.getTotal();
boolean hasNext = userPage.hasNext();//是否還有下一頁
boolean previous = userPage.hasPrevious();//上一頁
System.out.println(pages);
System.out.println(current);
System.out.println(records);
System.out.println(total);
}
5、MP刪除
- 簡單刪除,根據(jù)id刪除。簡單
- 批量刪除
- 和批量查詢一樣
- 簡單條件刪除,和上面一樣,使用map
5.1、物理刪除和邏輯刪除
物理刪除∶真實刪除,將對應(yīng)數(shù)據(jù)從數(shù)據(jù)庫中刪除,之后查詢不到此條被刪除數(shù)據(jù)(易懂)
**邏輯刪除︰**假刪除,將對應(yīng)數(shù)據(jù)中代表是否被刪除字段狀態(tài)修改為"被刪除狀態(tài)”,之后在數(shù)據(jù)庫中仍舊能看到此條數(shù)據(jù)記錄;
邏輯刪除
邏輯刪除實現(xiàn)的邏輯:
在表添加字段,作為邏輯刪除標(biāo)志,每次刪除時候,修改標(biāo)志位
0沒有刪除
1刪除
1.表添加字段,實體類添加屬性,這是標(biāo)志
2.增加注解@TableLogic :表邏輯
執(zhí)行刪除會將該字段的值設(shè)為1.
當(dāng)該字段的值為1時,MP查不到該數(shù)據(jù),但是該數(shù)據(jù)仍在數(shù)據(jù)庫中存在
6、條件構(gòu)造器和常用接口
Wapper的使用
public void testWrapper1() {
/**
* ge :大于等于
* gt: 大于
* le : <=
* lt : <
*/
QueryWrapper<User> wrapper = new QueryWrapper<>();
QueryWrapper<User> queryWrapper = wrapper.ge("age", 18);
List<User> users = userMapper.selectList(queryWrapper);
users.forEach(System.out::println);
}
SELECT id,name,age,email,create_time,update_time,version,deleted FROM user WHERE deleted=0 AND (age >= ?)
ge:大于等于
gt: 大于
le : <=
lt : <
eq :=
ne :!=
between: 閉區(qū)間
notBetween: 閉區(qū)間
用的多:模糊查詢
like 包含 %張%
notLike 不包含
likeLeft 張%
likeRight 張%
排序
orderBy、orderByDesc、orderByAsc. (參數(shù))
到此這篇關(guān)于MyBatis Plus實現(xiàn)數(shù)據(jù)庫curd操作的文章就介紹到這了,更多相關(guān)MyBatis Plus curd操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MyEclipse2017創(chuàng)建Spring項目的方法
這篇文章主要為大家詳細(xì)介紹了MyEclipse2017創(chuàng)建Spring項目的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03
SpringCloud Gateway的熔斷限流配置實現(xiàn)方法
Spring Cloud Gateway支持通過配置熔斷和限流機(jī)制來保證服務(wù)的穩(wěn)定性和可用性,可通過Hystrix和Resilience4j兩種方式實現(xiàn)。Hystrix通過注解和配置文件實現(xiàn)熔斷限流,Resilience4j通過編程式配置實現(xiàn)2023-04-04
hibernate關(guān)于session的關(guān)閉實例解析
這篇文章主要介紹了hibernate關(guān)于session的關(guān)閉實例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下2018-02-02

