MyBatis-Plus實現數據庫curd操作
1.mp是什么
- MyBatis-Plus(簡稱MP)是一個MyBatis 的增強工具,在MyBatis,的基礎上只做增強不做改變,為簡化開發、提高效率而生。
- 潤物無聲,
- 只做增強不做改變,引入它不會對現有工程產生影響,如絲般順滑。
- 效率至上,
- 只需簡單配置,即可快速進行CRUD操作,從而節省大量時間。
- 豐富功能
- 熱加載、代碼生成、分頁、性能分析等功能一應俱全。
mp實現添加修改刪除查詢
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,'[email protected]'), (2,'Jack',20,'[email protected]'), (3,'Tom',28,'[email protected]'), (4,'Sandy',21,'[email protected]'), (5,'Billie',24,'[email protected]');
sprinboot版本 2. 2.1
引入相關依賴
<!--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插件
配置數據庫信息
創建實體類User
創建對應的Mapper
繼承BaseMapper,里面封裝了常用的增刪查改方法
在啟動類上增加掃描該mapper的路徑。因為是該接口動態生成的,默認掃描不到、
@Autowired 對類成員變量、方法及構造函數進行標注,完成自動裝配的工作。
通過 @Autowired的使用來消除 set ,get方法
@Repository、@Service、@Controller 和 @Component 將類標識為Bean
@Repository(“名稱”):dao層
@Service(“名稱”):service層
@Controller(“名稱”):web層
#mybatis日志 開啟 mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
MP主鍵策略
ASSIGN_ID默認生成19位 (根據符號位,時間戳、、、等等生成,百度)auto:自動增長
默認開啟ASSIGN_ID
#全局設置主鍵生成策略
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, "[email protected]"); int insert = userMapper.insert(user); //影響行數 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("影響行數"+i); }
2.2、自動填充
字段賦值的時候需要set
增加兩個字段,對應的實體類也增加
@TableField(fill = FieldFill.INSERT) private Data createTime; @TableField(fill = FieldFill.INSERT_UPDATE) private Data updateTime;
新建一個類不要忘記添加注解將它交給Spring管理
@Component public class MyMetaObjectHandler implements MetaObjectHandler { //實現兩個方法,自動填充增加、修改 }
3、樂觀鎖
3.1、場景
主要適用場景:當要更新一條記錄的時候,希望這條記錄沒有被別人更新,也就是說實現線程安全的數據更新
解決丟失更新
的問題。(可重復讀,解決了不可重復讀,隔離性第三級別,Mysql默認)
樂觀鎖實現方式:
取出記錄時,獲取當前versione更新時,帶上這個versionv
執行更新時,set version = newexsion where version = oldVersion
如果version不對,就更新失敗
提交后修改版本號,另一個提交時,會先檢查版本號和獲取時是否一樣,不一樣提交失敗,一樣提交成功。
MP實現樂觀鎖。
1.顯然,需要在表中加上字段version,實體類也是
添加注解@Version即可
3.配置樂觀鎖插件,Spring Boot創建一個配置類
添加配置注解,添加掃描,創建一個樂觀鎖插件
@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的屬性 不對應數據庫中的也能查詢到
4.3、分頁查詢
邏輯
public void selectPage() { Page<User> page = new Page<>(1,3); Page<User> userPage = userMapper.selectPage(page,null); long pages = userPage.getPages();//總頁數 long current = userPage.getCurrent();//當前頁 List<User> records = userPage.getRecords();//數據集合 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刪除
- 簡單刪除,根據id刪除。簡單
- 批量刪除
- 和批量查詢一樣
- 簡單條件刪除,和上面一樣,使用map
5.1、物理刪除和邏輯刪除
物理刪除∶真實刪除,將對應數據從數據庫中刪除,之后查詢不到此條被刪除數據(易懂)
**邏輯刪除U**假刪除,將對應數據中代表是否被刪除字段狀態修改為"被刪除狀態”,之后在數據庫中仍舊能看到此條數據記錄;
邏輯刪除
邏輯刪除實現的邏輯:
在表添加字段,作為邏輯刪除標志,每次刪除時候,修改標志位
0沒有刪除
1刪除
1.表添加字段,實體類添加屬性,這是標志
2.增加注解@TableLogic :表邏輯
執行刪除會將該字段的值設為1.
當該字段的值為1時,MP查不到該數據,但是該數據仍在數據庫中存在
6、條件構造器和常用接口
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: 閉區間
notBetween: 閉區間
用的多:模糊查詢
like 包含 %張%
notLike 不包含
likeLeft 張%
likeRight 張%
排序
orderBy、orderByDesc、orderByAsc. (參數)
到此這篇關于MyBatis Plus實現數據庫curd操作的文章就介紹到這了,更多相關MyBatis Plus curd操作內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/qq_44769557/article/details/120464415