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>类,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<T>,就可以通过实体类调用CRUD方法(通过继承Model<T>得来的)。

1)两个条件:

         继承BaseMapper<T>;

         继承Model<T>;

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

图A
图B

六、通用Service

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Boot: Spring Doc生成OpenAPI3.0文档 1. 概述 公司正好最近在整理项目的文...
    陆理手记阅读 386评论 0 0
  • 一周一次的读书会,如期而至。今天我们有新朋友的加入。一起来认识一下吧。我们的家人:羿丹,坐在晓庆宝宝的旁边。 羿丹...
    明瑰阅读 362评论 0 1
  • 1、异步消息队列 Redis的list(列表)数据结构常用来作异步消息队列使用,用rpush和lpush操作入队列...
    代码的搬运工阅读 1,272评论 1 0