微服务Day01 MP

mybatisPlus通过扫描实体类,并基于反射获取实体类信息作为数据库表信息

那么我们怎么知道它操作哪张表?

类名驼峰转下划线作为表明

名为id的字段名作为主键

变量名驼峰转下划线作为表的字段名

常见注解

@TableName:用来指定表名

@TableId:用来指定表中的主键字段信息

@TableField:用来指定表中的普通字段信息

@TableId指定表中的主键字段信息,而表中的自增代表着类型

IdType枚举:

AUTO:数据库自增长

INPUT:通过set方法自行输入

ASSIGN_ID:分配ID接口IdentifierGenerator的方法nextId来生成id默认实现类为DefaultIdentifierGenerator雪花算法

使用@TableField的常见场景:

成员变量名与数据库字段名不一致

成员变量名与is开头且是布尔值

成员变量名与数据库关键字冲突

成员变量不是数据库字段

id为主键类型为自增

name与数据库表中的字段名不一致

isMarried成员变量名与is开头,且是布尔值

order成员变量名与数据库关键字冲突

address 成员变量不是数据库字段

条件构造,设计到复杂的语句

List<Long>ids=List.of(1L,2L,4L);

UpdateWrapper<User>wrapper=new updateWrapper<User>()

.setSql("balance=balance-200")

.in("id",ids);

自定义sql:我们可以利用MybatisPlus的Wrapper来构建复杂的Where条件,然后自己定义SQL语句中剩下的部分

  1. 基于Wrapper构建where条件

List<Long>ids=List.of(1L,2L,4L);

int amount=200;

LambdaQueryWrapper<User>wrapper=new LambdaQueryWrapper<User>().in(User::getId,ids);

//2.自定义SQL语句的调用方法

userMapper.updateBalanceByIds(wrapper,amount);

//3.在mapper方法参数中用Param注解声明wrapper变量名称,必须是ew

void updateBalanceByIds(@Param("ew") LambdaQueryWrapper<User>wrapper,@Param("amount) int amount );

自定义SQL,并使用Wrapper条件

<update id="updateBalanceByIds">

UPDATE tb_user SET balance = balance-#{amount} ${ew.customSqlSegment}

</update>

Service接口

因为Restful风格一般表格都是用JSON格式来传参,所以需要用@RequestBody成功接收参数

因为我们要传的参数User,所以我们要用到BeanUtil来传参

这里我们再次定义一个实参类型来接收参数

用UserQuery参数来接收

而Service层主要是用lambdaQuery()

最后一个就是把返回的结果怎么样,.list就是把它转换成list结果,另外,就是第一个参数就是是否存在,就 和 if test=" !=null"一样的作用,但是lambda的更简单,User::getUsername得到的是字段名

但是我们发现如果多个线程执行一次的时候会出现异常,就是两个人同时访问,但是最后金额就减了一次,所以我们需要进行上锁进行处理

相关推荐
●VON6 小时前
鸿蒙Flutter实战:分类管理页BottomSheet CRUD
数据库·flutter·华为·harmonyos·鸿蒙
Cosolar6 小时前
Chroma向量库面试学习指南
数据库·人工智能·面试·职场和发展·数据库架构
企服AI产品测评局8 小时前
Agent适配信创环境实测:企业级自动化如何实现国产操作系统与数据库全兼容?
运维·数据库·人工智能·ai·chatgpt·自动化
cfm_29148 小时前
Redis数据安全性解析
数据库·redis·缓存
DIY源码阁8 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
NiceCloud喜云9 小时前
Claude Code Routines 实战:三种触发器跑通云端自动化编码
android·运维·数据库·人工智能·自动化·json·飞书
辞忧九千七9 小时前
Redis 单机一主二从主从复制完整搭建指南
数据库·redis·缓存
lzhdim10 小时前
SQL 入门 16:SQL 事务隔离级别与死锁解析(易懂)
数据库·sql
AI 小老六11 小时前
Claude Code 如何压缩上下文:Microcompact、Prompt Cache 与 cache_edits 工程拆解
数据库·人工智能·ai·语言模型·架构·系统架构
Chasing__Dreams11 小时前
Redis--基础知识点--32--redis底层存储结构
数据库·redis·缓存