IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> mybatis-plus基础知识 -> 正文阅读

[Java知识库]mybatis-plus基础知识

mybatis-plus基础知识

特性

在这里插入图片描述

快速入门

1.连接数据库
在这里插入图片描述
2.pojo类

在这里插入图片描述

3.新建mapper包并新建一个mapper接口,如下:

package com.example.mybatisplus.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.mybatisplus.pojo.User;

// 继承BaseMapper接口即可
public interface UserMapper extends BaseMapper<User> {

}

4.在主启动类上开启注解扫描
在这里插入图片描述

4.测试

package com.example.mybatisplus;

import com.example.mybatisplus.mapper.UserMapper;
import com.example.mybatisplus.pojo.User;
import org.junit.jupiter.api.Test;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.List;


@SpringBootTest
class MybatisPlusApplicationTests {
	@Autowired
	private UserMapper userMapper;

	@Test
//	查询所有数据
	public void user_Test() {
		System.out.println(("----- selectAll method test ------"));
		List<User> userList = userMapper.selectList(null);
		userList.forEach(System.out::println);
	}

}

mybatis与mybatis-plus的区别

在这里插入图片描述

配置日志的输出

在这里插入图片描述

插入测试及雪花算法

在这里插入图片描述

主键生成策略

默认ID_WORKER (全局唯一id)

在这里插入图片描述
这里mybatis-plus使用的是雪花算法

雪花算法
在这里插入图片描述

主键自增

1.需要将数据库的id字段设为自增
2.在实体类id字段上配置注解@TableId(type = IdType.AUTO)

几种不同的主键自增策略

    AUTO(0), // id自增
    NONE(1),  // 未设置主键自增策略   
    INPUT(2), // 手动输入
    ASSIGN_ID(3),  // 
    ASSIGN_UUID(4), //
    /** @deprecated */  
    @Deprecated
    ID_WORKER(3), // 默认的全局唯一id
    /** @deprecated */
    @Deprecated
    ID_WORKER_STR(3),  // 全局唯一表示法 截取字符串
    /** @deprecated */
    @Deprecated
    UUID(4);  // 全局唯一id

更新操作

@Test
	public void updateData(){
		User user=new User();
		user.setUser("yang yang");
		user.setAge(23);
		user.setPass("123");
		user.setSex("man");
		user.setId(6);
		// 注意:这里的updateById方法的参数是一个对象
		int count=userMapper.updateById(user);
		System.out.println(count);
	}

自动填充

在这里插入图片描述

数据库级别

在这里插入图片描述

在这里插入图片描述

代码级别

在这里插入图片描述
在这里插入图片描述

编写处理器来处理注解

这样的话,在执行插入和更新操作时,会将数据的updateTime和inserTime字段的值进行自动插入和更新

/*
	如果不想每次都写private
	final Logger logger = LoggerFactory.getLogger(当前类名.class); 可以用注解@Slf4j;
* */
@Slf4j
@Component
public class MyMetaHandler implements MetaObjectHandler {

//	插入时的策略
	@Override
	public void insertFill(MetaObject metaObject) {
		log.info("start inserfill...");
		this.setFieldValByName("createTime",new Date(),metaObject);
		this.setFieldValByName("updateTime",new Date(),metaObject);
	}

//更新时的策略
	@Override
	public void updateFill(MetaObject metaObject) {
		log.info("start updatefill...");
		this.setFieldValByName("updateTime",new Date(),metaObject);
	}
}

乐观锁处理

编写Configuration配置类

@Configuration
public class mybatisplusConfig {

	//	注册乐观锁插件
	@Bean
	public OptimisticLockerInterceptor optimisticLockerInterceptor(){
		return new OptimisticLockerInterceptor();
	}
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

模拟线程插队的更新操作

User user=userMapper.selectById(8); //version=2
		user.setUser("kuangsheng");

//		模拟插队线程的操作
		User user1=userMapper.selectById(8);
		user1.setUser("kuangsheng111");
		userMapper.updateById(user1); //version=3

		/*
		下面这句查询其实为 select* from user where version =2 
		(但数据库并没有version=2的数据,所以就会导致更细失败!)
		因为上面的操作将version变成3了,这就是乐观锁的机制
		*/
		int count=userMapper.updateById(user); //如果没有乐观锁,则改端代码的结果会 覆盖 插队线程的操作

查询操作

批量查询

List<User> userList=userMapper.selectBatchIds(Arrays.asList(1,2,3));
		userList.forEach(System.out::println);

多条件查询

Map<String,Object> map=new TreeMap<>();
		map.put("user","李福");
		List<User> userList= userMapper.selectByMap(map);
		System.out.println(userList);

分页查询

1.配置拦截器组件

//	配置分页插件
	@Bean
	public PaginationInterceptor paginationInterceptor() {
		PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
		paginationInterceptor.setCountSqlParser(new JsqlParserCountOptimize(true));
		return paginationInterceptor;
	}

测试

		//curren:当前页 size:每页数据条数
		Page<User> page=new Page<>(1,5);
		userMapper.selectPage(page,null);
		List<User> userList=page.getRecords();
		userList.forEach(System.out::println);
	}

删除操作

在这里插入图片描述
单个删除

int count=userMapper.deleteById(7);
		if (count>0){
			System.out.println("删除成功!!!");
		}

批量删除

int count=userMapper.deleteBatchIds(Arrays.asList(5,6));
		if (count>0){
			System.out.println("批量删除成功!!!");
		}

通过map删除

Map<String,Object> map=new HashMap<>();
		map.put("user","liifu");
		map.put("user","cyh");
		int count=userMapper.deleteByMap(map);
		if(count>0){
			System.out.println("删除成功!!");
		}

逻辑删除

在这里插入图片描述
1.数据库增加一个deleted字段

2.pojo类增加对应deleted字段

3.编写Config配置

在这里插入代码片

4.配置文件(application.yml)

#配置日志
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  #逻辑删除
  global-config:
    db-config:
      logic-delete-value: 1      #即删除为1
      logic-not-delete-value: 0  #未删除为0

注意点

1.要在主启动类上使用@MapperScan注解扫描mapper下的包

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-12-24 18:20:30  更:2021-12-24 18:21:26 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 7:37:03-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码