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知识库 -> SpringBoot项目引入MybatisPlus -> 正文阅读

[Java知识库]SpringBoot项目引入MybatisPlus

SpringBoot项目引入MybatisPlus

mybatis-plus是对mybatis的一个简化和升级。

核心是给所有的Mapper接口抽取了一个父接口,让所有的Mapper接口继承父接口来实现;给所有的Service接口也抽取了一个父接口,让所有的Service接口也继承父接口来实现。

第一步:

? 导入依赖

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>3.5.1</version>
</dependency>

<dependency>
    <groupId>org.freemarker</groupId>
    <artifactId>freemarker</artifactId>
    <version>2.3.31</version>
</dependency>

第二步:

? 配置文件

#应用名称
spring.application.name=SbmpDemo
#应用服务访问端口
server.port=8080

#-------------------------配置数据源---------------------------------------

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/db_mp?serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=1234

#-----配置mybatis-plus(和mybatis的配置一样,只是属性前缀变为了mybatis-plus)-----

#注册sql映射文件(resources/mapper/*.xml)
mybatis-plus.mapper-locations=classpath:mapper/*.xml
#输出日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
#开启驼峰命名规则
mybatis-plus.configuration.map-underscore-to-camel-case=true

第三步:

? 启动类或mapper接口上添加注解

//启动类添加注解,表示开启包扫描
@MapperScan(basePackages = "com.xxx.mapper")

? 或

//在mapper接口上添加注解
@Mapper

分页查询:

? service.page();

? mapper.selectPage();

多行查询:

? service.list();

Wrapper条件对象的方法:

? 一般new它的子类对象:

? LambdaQueryWrapper<>对象和QueryWrapper<>对象

		  eq(String column, V) -- 等于
          ne(String column, V) -- 不等于
          gt(String column, V) -- 大于
          ge(String column, V) - -大于等于
          lt(String column, V) -- 小于
          le(String column, V) -- 小于等于
          allEq(Map<String column, V>) -- 全等于
          between(String column, V1, V2) -- between and
          in(String column, Object...Values) -- in
          like(String column, V) -- like模糊查询
          orderByAsc(String column) -- 升序排序
          orderByDesc(String column) -- 降序排序
          groupBy(String column) -- 分组

关于事务

对数据库增删改的方法上可添加注解

@Transactional(rollbackFor = Exception.class)

关于缓存

代码注入redis中进行缓存

        //先判断redis中是否已经有缓存的数据了
        String redis_value = redisTemplate.opsForValue().get("键");
		//有的话转换为需要返回的对象,然后返回即可
		return JSON.parseArray(redis_value,需要返回的类.class);
		//查询数据后,转换为json字符串
		String jsonStr = JSON.toJSONString(查询到的数据);
		//存入redis
		redisTemplate.opsForValue().set("键",jsonStr, Duration.ofDays(7));

注解注入redis

@EnableCaching //在启动类上加上注解启动缓存

//作用在你要缓存的数据上
@Cacheable//在方法上添加注解(添加缓存) 
@Cacheput //在方法上添加注解;解决脏读 每次都会执行一次数据库查询,然后把查到的值存入缓存中 一般用于更新
@CachEvict//在方法上添加注解;(解决脏读)
@CacheConfig//在类上添加注解;(全局的配置缓存)
//注解式存储的时候,因为会自动将返回的数据转换为json数据
//所以需要实体类实现Serializable接口
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-09-25 23:07:16  更:2022-09-25 23:07:28 
 
开发: 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/23 8:58:07-

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