一、相关介绍
1)Mybatis与JPA(Java Persistence API的简称,中文名Java持久层API)的优劣势



2)Mybatis-Plus特性

3)Mybatis-Plus框架结构

4)SSM传统编程模式

二、快速入门
1)Maven导入相关依赖
PS:Mysql jdbc驱动依赖不用指定版本号,因为Springboot默认配置了该驱动的版本号


2)配置要连接的数据库的相关信息(注意:yml文件要命名为application,springboot默认扫描以application命名的文件进行配置)

3) Dao层继承BaseMapper<T>类,T指代对应的实体类。如下图所示,所用的是实体类User。
BaseMapper里有着许多已经实现的CRUD方法,一些简单的单表CRUD方法直接调用即可,无需再编写。

三、数据库映射
1)相关注解

2)非表字段,即数据库里没有,但存在于实体类里的属性。使用以下方法,在对表数据操作时,会忽略这些属性。
1、使用static修饰

2、使用transient修饰

3、使用@TableField注解

四、查询相关(CRUD差不多,所以只记录查询)
1)使用...byMap方法时,注意key值是数据库里的字段名。如果放入的是实体类的属性名,而属性名和数据库里的字段不同,则会报错。

2)条件构造器
1、57、58行是创建条件构造器的两种方式,下图表示创建实体类User的条件构造器。

2、99、100行两钟方法建议使用第一种。第二种方法如果按图示传入,字符串末的or true会被当做sql语句,会查出不该查的数据。

3、233行是把实体类做为参数,执行sql查询时只会根据set的值(下图的Name、Age属性)进行条件判断查询,如图A所示。


4、codition作用

5、allEq作用


6、lambda条件构造器
下图是三种创建方式

7、自定义sql
1)注解方式

2、xml方式


8)分页查询

五、AR模式(直接用实体操作数据库)
实体类继承Model<T>,就可以通过实体类调用CRUD方法(通过继承Model<T>得来的)。
1)两个条件:
继承BaseMapper<T>;
继承Model<T>;
2)继承Model<T>时,如报图A的错误是因为生成的equals方法没有调用父类。如果不想调用,可加上注解@WqualsAndHashCode(callSuper==false),如图B所示。


六、通用Service
需要继承ServiceImpl<UserMapper,User>,实现 UserService。达到的效果如同AR模式一样,可以通过Service调用CRUD方法。

