Java学习Day34-MyBatis-Plus框架

持久层

操作数据存储的层

与什么数据库无关

与什么拘束无关

ORM

O(Object) R(Relationship) M(Mapping)对象关系映射

Mybatis框架就是一款持久层ORM框架

Mybatis 与 JDBC 的关系

Mybatis的底层是JDBC,基于反射技术在运行时调用JDBC,实现数据库编程

Mybatis - Plus是苞米豆baomidou公司的

MyBatis-Plus

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,也可以传""

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值