) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
实体类
创建实体类UserAddress
mapper
创建UserAddressMapper接口
测试
注入mapper对象
insert 记录:
日志:
表
CREATE TABLE salary
(
id
int(11) NOT NULL AUTO_INCREMENT,
empid
int(11) NOT NULL,
empsal
float(10,2) NOT NULL,
PRIMARY KEY (id
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
实体类
mapper
测试
注入mapper对象
添加
日志
列名使用下划线,属性名是驼峰命名方式。MyBatis 默认支持这种规则。
表定义
CREATE TABLE customer
(
id
int(11) NOT NULL AUTO_INCREMENT,
cust_name
varchar(50) DEFAULT NULL,
cust_age
int(11) DEFAULT NULL,
cust_email
varchar(100) DEFAULT NULL,
PRIMARY KEY (id
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
实体类
mapper
测试
注入mapper对象
添加
日志
数据库
定义表
CREATE TABLE student
(
id
int(11) NOT NULL AUTO_INCREMENT,
name
varchar(80) DEFAULT NULL,
age
int(11) DEFAULT NULL,
email
varchar(80) DEFAULT NULL,
status
int(11) DEFAULT NULL,
PRIMARY KEY (id
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
insert into student values(null,‘张三’,22,‘zs@sina.com’,1);
实体
创建 Mapper
新建 sql 映射 xml 文件
配置 xml 文件位置
application.yml
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
mapper-locations: classpath*:xml/*Mapper.xml
测试
日志:
查询构造器:Wrapper
QueryWrapper(LambdaQueryWrapper) 和UpdateWrapper(LambdaUpdateWrapper)的父类用于生成 sql 的 where 条件, entity 属性也用于生成 sql 的 where 条件. MP3.x开始支持lambda表达式,LambdaQueryWrapper,LambdaUpdateWrapper支持 lambda表达式的构造查询条件。
条件:
| 条件 | 说明 |
| — | — |
| allEq | 基于 map 的相等 |
| eq | 等于 = |
| ne | 不等于 <> |
| gt | 大于 > |
| ge | 大于等于 >= |
| lt | 小于 < |
| le | 小于等于 <= |
| between | BETWEEN 值1 AND 值2 |
| norBetween | NOT BETWEEN 值1 AND 值2 |
| like | LIKE ‘%值%’ |
| notLike | NOT LIKE ‘%值%’ |
| likeLeft | LIKE ‘%值’ |
| likeRight | LIKE ‘值%’ |
| isNull | 字段 IS NULL |
| isNotNull | 字段 IS NOT NULL |
| in | 字段 IN (value1, value2, …) |
| notIn | 字段 NOT IN (value1, value2, …) |
| inSql | 字段 IN ( sql 语句 ) |
| notInSql | 字段 NOT IN ( sql 语句 ) |
| groupBy | GROUP BY 字段 |
| orderByAsc | 升序 ORDER BY 字段, … ASC |
| orderByDesc | 降序 ORDER BY 字段, … DESC |
| orderBy | 自定义字段排序 |
| having | 条件分组 |
| or | OR 语句,拼接 + OR 字段=值 |
| and | AND 语句,拼接 + AND 字段=值 |
| apply | 拼接 sql |
| last | 在 sql 语句后拼接自定义条件 |
| exists | 拼接 EXISTS ( sql 语句 ) |
| notExists | 拼接 NOT EXISTS ( sql 语句 ) |
| nested | 正常嵌套 不带 AND 或者 OR |
QueryWrapper:查询条件封装类
| 方法 | 说明 |
| — | — |
| select | 设置查询字段 select 后面的内容 |
UpdateWrapper:更新条件封装类
| 方法 | 说明 |
| — | — |
| set | 设置要更新的字段,MP 拼接 sql 语句 |
| setSql | 参数是 sql 语句,MP 不在处理语句 |
查询
Student 表:初始数据
以 Map 为参数条件
a) 条件:name 是张三,age 是 22
日志:where name=”张三” and age = 22
b) 查询条件有 null
true 日志:
false日志:
name 等于李四
日志
ne 不等于
日志
gt 大于
日志
ge 大于等于
日志
lt 小于
日志
le 小于等于 <=
日志
between 在两个值范围之间
日志
notBetween 不在两个值范围之间
日志
like 匹配值 “%值%”
notLike 不匹配 “%值%”
日志
likeLeft 匹配 like “%值”
likeRight 匹配 like “值%”
先自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以扫码领取!
![img](https://img-blog.csdnimg.cn/img_convert/12897d7748b15c3393f46ba7b221a76f.jpeg)
《MySql面试专题》
《MySql性能优化的21个最佳实践》
《MySQL高级知识笔记》
文中展示的资料包括:**《MySql思维导图》《MySql核心笔记》《MySql调优笔记》《MySql面试专题》《MySql性能优化的21个最佳实践》《MySq高级知识笔记》**如下图
关注我,点赞本文给更多有需要的人
g-85qjo369-1711400939223)]
《MySQL高级知识笔记》
[外链图片转存中…(img-c8UjVBa7-1711400939223)]
[外链图片转存中…(img-KacG97XB-1711400939223)]
[外链图片转存中…(img-tXwzXjFI-1711400939224)]
[外链图片转存中…(img-E0U4CFXP-1711400939224)]
[外链图片转存中…(img-QabVubhO-1711400939224)]
[外链图片转存中…(img-vDoaDVBG-1711400939224)]
[外链图片转存中…(img-3s8eiT5b-1711400939225)]
[外链图片转存中…(img-Vj48aqcF-1711400939225)]
[外链图片转存中…(img-JTaBhViP-1711400939225)]
[外链图片转存中…(img-N3Kop6ai-1711400939225)]
文中展示的资料包括:**《MySql思维导图》《MySql核心笔记》《MySql调优笔记》《MySql面试专题》《MySql性能优化的21个最佳实践》《MySq高级知识笔记》**如下图
[外链图片转存中…(img-tAJoPLS7-1711400939226)]
关注我,点赞本文给更多有需要的人
需要更多Java资料的小伙伴可以帮忙点赞+关注,点击传送门,即可免费领取!