持久层
操作数据存储的层
与什么数据库无关
与什么拘束无关
ORM
O(Object) R(Relationship) M(Mapping)对象关系映射
Mybatis框架就是一款持久层ORM框架
Mybatis 与 JDBC 的关系
Mybatis的底层是JDBC,基于反射技术在运行时调用JDBC,实现数据库编程
Mybatis - Plus是苞米豆baomidou公司的
Mybatis - Plus 与 SpringBoot的关系
Mybatis-Plus框架能够与SpringBoot框架无缝衔接
学习一门框架的步骤
1、搭建环境
安装哪些依赖(三方库)
需要哪些配置
框架提供了哪些API,怎么用
2、如何应用
3、研究底层的实现
Idea搭建环境
创建工程
.cj是8.X版本的 ,我们需要对mysql的版本降级,减为5.1.47版本
Mybatis-Plus基础配置参数
代码写在工程的哪个包里面
dao包(用原生的JDBC写)
mapper包 (用Mybatis-Plus框架写,包名建议mapper)
包的关系
基础父包
公司名.当前工程名(g.a)
模块子包
dao、util、entity等
创建持久层的子包
entity写实体类
mapper写与数据库有关
子包与启动类同级
在mapper包中写接口
在xml文件编写sql语句
xml文件写在resources文件中
设置xml文件头(约束当前xml可以写什么标签)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
根标头
<mapper>
</mapper>
使用Mybatis-Plus的时候Idea给我们提供了一个插件MybatisX,用于接口和xml文件之间的快速访问
xml文件与接口连好的情况下,在接口 alt+回车 也可以在xml快速创建编写sql语句的标签
在启动类中使用@MspperScan("mapper包的全路径")
如何拿到Mapper接口的实现类?
拿不到,因为没有物理文件,它存放在JVM内存中
静态编程:程序不启动时文件不存在(自己写的接口,静态编程 - 物理文件)
动态编程:程序启动后文件在内存里面运行
如何拿到框架创建的Mapper接口的实现类的对象?
框架说:类你拿不到,我会把对象创建好放到内存中,让你去拿对象
启动类中拿对象的两种方式(类、类型)
拿对象的方式(注解)
测试的时候显示SQL语句的配置
开启SQL日志打印功能,方便在测试的时候排查错误
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
动态SQL语句的编写
Mybatis写SQL语句的几种方式
1、在绑定的xml文件中写
2、不需要xml文件,使用注解写
(动态SQL语句还是在xml文件中写)
使用注解实现SQL语句
1、List<T> selectByMap(@Param("cm") map<String,Object> columnMap);
底层的SQL的语句是:
当没写条件时是查询全表
SELECT id,username,password,avatar,sex,mobile,id_code,is_delete,modify_date FROM user
当写了条件的时候,后面会拼接 where 条件=?
SELECT id,username,password,avatar,sex,mobile,id_code,is_delete,modify_date FROM user WHERE 条件 = ? AND username = ?
当多个条件时,后面用and连接
SELECT id,username,password,avatar,sex,mobile,id_code,is_delete,modify_date FROM user WHERE 条件 = ? AND 条件 = ?
允许超范围查询
2、List<T> selectBatchIds(@Param("coll") Collection<? extends Serializable> idList);
底层的SQL语句是:
SELECT id,username,password,avatar,sex,mobile,id_code,is_delete,modify_date FROM user WHERE id IN ( )
当没有数据传进去的时候,报错;
当传一个null进去的时候,正常查询,没有返回结果,因为没有符合条件的数据
当传一个或多个数据进去的时候,正常查询,可能有返回结果
允许超范围查询
3、int selectById(Serializable id);
底层的SQL语句是:
SELECT id,username,password,avatar,sex,mobile,id_code,is_delete,modify_date FROM user WHERE id=?
允许传空和空字符串
4、int update(@Param("et") T entity);
底层的SQL语句是:
UPDATE user WHERE id=?
id可以为null,修改的字段不能为null,可以为""(空字符串)
5、int deleteBatchIds(@Param("coll")Collection<?extends Serializable>isList);
底层的SQL语句是:
DELETE FROM user WHERE id IN ( )
当没有数据传进去的时候,报错;
当传一个null进去的时候,正常查询,没有返回结果,因为没有符合条件的数据
当传一个或多个数据进去的时候,正常查询,可能有返回结果
允许超范围查询
6、int deleteByMap(@(Param("cm")Map<String,Object>colunmnMap);
底层的SQL语句是:
DELETE FROM user
可以传null
7、int deleteById(Serializable id);
底层的SQL语句是:
DELETE FROM user WHERE id=?
不能传null,也不能传"",不能超范围查询
8、int insert(T entity);
可以传null,也可以传""