一、相关介绍
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方法。