Mybatis-Plus基础学习笔记

一、相关介绍

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指代对应的实体类。如下图所示,所用的是实体类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所示。

图A

4、codition作用

5、allEq作用

6、lambda条件构造器

下图是三种创建方式

7、自定义sql

1)注解方式

2、xml方式

8)分页查询

五、AR模式(直接用实体操作数据库)

实体类继承Model,就可以通过实体类调用CRUD方法(通过继承Model得来的)。

1)两个条件:

         继承BaseMapper

         继承Model

2)继承Model时,如报图A的错误是因为生成的equals方法没有调用父类。如果不想调用,可加上注解@WqualsAndHashCode(callSuper==false),如图B所示。

图A
图B

六、通用Service

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

你可能感兴趣的:(Mybatis-Plus基础学习笔记)