MyBatis-Plus入门之ActiveRecord模式,2024年最新java面试逻辑题答案及解析

日志:

在这里插入图片描述

数据库:

在这里插入图片描述

AR 之 update


在这里插入图片描述

创建实体对象,对要更新的属性赋值,null 的属性不更新,根据主键更新记录。

返回值是 boolean,true 更新成功。没有更新记录是 false。

日志:

在这里插入图片描述

数据库:

在这里插入图片描述

AR 之 delete


在这里插入图片描述

使用主键作为删除条件,deleteById()参数是主键值,sql 语句条件是 where id=1。

返回值始终是 true。通过源码查看:

在这里插入图片描述

可以看到deleteById内部调用了delBool

在这里插入图片描述

删除返回值判断条件是 result >=0 ,只有 sql 语法是正确的,返回就是 true。和删除记录的数量无关。

日志:

在这里插入图片描述

此时数据库已经为空!

为了方便演示后面的查询操作,将 AR 之 Insert的操作多运行几次,保证数据库有数据

这里我就运行3次

在这里插入图片描述

AR 之 select


对象调用 selectById()

在这里插入图片描述

对象提供主键值,调用 selectById()无参数,使用 id=2 作为查询条件,返回值是查询的结果对象:

在这里插入图片描述

没有查询到对象不会报错,返回是 null:

在这里插入图片描述

selectById(主键)


不需要依赖对象提供主键值,直接selectById(主键值)

在这里插入图片描述

创建对象,不设值 id 主键值, selectById 的参数是查询条件,和对象的属性值

无关。返回值是结果对象,id 不存在返回 null。

不提供主键 id 值会报错:

在这里插入图片描述

报错如下:

com.baomidou.mybatisplus.core.exceptions.MybatisPlusException: selectById primaryKey is null.

如图:

在这里插入图片描述

selectAll


查询所有数据,返回值是List集合

在这里插入图片描述

日志:

在这里插入图片描述

查询操作是最多的,其它方法的使用在介绍 Wrapper 对象后讲解


在这里插入图片描述

表和列


主键 ,TableName, TableId

主键类型

IdType 枚举类,主键定义如下:

在这里插入图片描述

  • 0.none 没有主键

  • 1.auto 自动增长(mysql, sql server)

  • 2.input 手工输入

  • 3.id_worker: 实体类用 Long id , 表的列用 bigint ,int 类型大小不够

  • 4.id_worker_str 实体类使用 String id, 表的列使用 varchar 50

  • 5.uuid 实体类使用 String id, 列使用 varchar 50

  • id_worker: Twitter 雪花算法-分布式 ID

指定表名


定义实体类,默认的表名和实体类同名;如果不一致,在实体类定义上面使用@TableName 说明表名称。

例如:@TableName(value=”数据库表名”)

步骤:

CREATE TABLE user_address (

id int(11) NOT NULL AUTO_INCREMENT,

city varchar(50) DEFAULT NULL,

street varchar(255) DEFAULT NULL,

zipcode varchar(255) DEFAULT NULL,

PRIMARY KEY (id)

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

在这里插入图片描述

实体类

创建实体类UserAddress

在这里插入图片描述

mapper

创建UserAddressMapper接口

在这里插入图片描述

测试

注入mapper对象

在这里插入图片描述

insert 记录:

在这里插入图片描述

日志:

在这里插入图片描述

指定列名


CREATE TABLE salary (

id int(11) NOT NULL AUTO_INCREMENT,

empid int(11) NOT NULL,

empsal float(10,2) NOT NULL,

PRIMARY KEY (id)

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

在这里插入图片描述

实体类

在这里插入图片描述

mapper

在这里插入图片描述

测试

注入mapper对象

在这里插入图片描述

添加

在这里插入图片描述

日志

在这里插入图片描述

驼峰命名


列名使用下划线,属性名是驼峰命名方式。MyBatis 默认支持这种规则。

表定义

CREATE TABLE customer (

id int(11) NOT NULL AUTO_INCREMENT,

cust_name varchar(50) DEFAULT NULL,

cust_age int(11) DEFAULT NULL,

cust_email varchar(100) DEFAULT NULL,

PRIMARY KEY (id)

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

在这里插入图片描述

实体类

在这里插入图片描述

mapper

在这里插入图片描述

测试

注入mapper对象

在这里插入图片描述

添加

在这里插入图片描述

日志

在这里插入图片描述

数据库

在这里插入图片描述

自定义 sql


定义表

CREATE TABLE student (

id int(11) NOT NULL AUTO_INCREMENT,

name varchar(80) DEFAULT NULL,

age int(11) DEFAULT NULL,

email varchar(80) DEFAULT NULL,

status int(11) DEFAULT NULL,

PRIMARY KEY (id)

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

insert into student values(null,‘张三’,22,‘zs@sina.com’,1);

在这里插入图片描述

实体

在这里插入图片描述

创建 Mapper

在这里插入图片描述

新建 sql 映射 xml 文件

在这里插入图片描述

配置 xml 文件位置

application.yml

mybatis-plus:

configuration:

log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

mapper-locations: classpath*:xml/*Mapper.xml

在这里插入图片描述

测试

在这里插入图片描述

日志:

在这里插入图片描述

查询和分页


查询构造器:Wrapper

在这里插入图片描述

QueryWrapper(LambdaQueryWrapper) 和UpdateWrapper(LambdaUpdateWrapper)的父类用于生成 sql 的 where 条件, entity 属性也用于生成 sql 的 where 条件. MP3.x开始支持lambda表达式,LambdaQueryWrapper,LambdaUpdateWrapper支持 lambda表达式的构造查询条件。

条件:

| 条件 | 说明 |

| — | — |

| allEq | 基于 map 的相等 |

| eq | 等于 = |

| ne | 不等于 <> |

| gt | 大于 > |

| ge | 大于等于 >= |

| lt | 小于 < |

| le | 小于等于 <= |

| between | BETWEEN 值1 AND 值2 |

| norBetween | NOT BETWEEN 值1 AND 值2 |

| like | LIKE ‘%值%’ |

| notLike | NOT LIKE ‘%值%’ |

| likeLeft | LIKE ‘%值’ |

| likeRight | LIKE ‘值%’ |

| isNull | 字段 IS NULL |

| isNotNull | 字段 IS NOT NULL |

| in | 字段 IN (value1, value2, …) |

| notIn | 字段 NOT IN (value1, value2, …) |

| inSql | 字段 IN ( sql 语句 ) |

| notInSql | 字段 NOT IN ( sql 语句 ) |

| groupBy | GROUP BY 字段 |

| orderByAsc | 升序 ORDER BY 字段, … ASC |

| orderByDesc | 降序 ORDER BY 字段, … DESC |

| orderBy | 自定义字段排序 |

| having | 条件分组 |

| or | OR 语句,拼接 + OR 字段=值 |

| and | AND 语句,拼接 + AND 字段=值 |

| apply | 拼接 sql |

| last | 在 sql 语句后拼接自定义条件 |

| exists | 拼接 EXISTS ( sql 语句 ) |

| notExists | 拼接 NOT EXISTS ( sql 语句 ) |

| nested | 正常嵌套 不带 AND 或者 OR |

QueryWrapper:查询条件封装类

| 方法 | 说明 |

| — | — |

| select | 设置查询字段 select 后面的内容 |

UpdateWrapper:更新条件封装类

| 方法 | 说明 |

| — | — |

| set | 设置要更新的字段,MP 拼接 sql 语句 |

| setSql | 参数是 sql 语句,MP 不在处理语句 |

查询

Student 表:初始数据

在这里插入图片描述

allEq


以 Map 为参数条件

a) 条件:name 是张三,age 是 22

在这里插入图片描述

日志:where name=”张三” and age = 22

在这里插入图片描述

b) 查询条件有 null

在这里插入图片描述

true 日志:

在这里插入图片描述

false日志:

在这里插入图片描述

eq


name 等于李四

在这里插入图片描述

日志

在这里插入图片描述

ne


ne 不等于

在这里插入图片描述

日志

在这里插入图片描述

gt


gt 大于

在这里插入图片描述

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

结尾

查漏补缺:Java岗 千+道面试题Java基础+全家桶+容器+反射+异常等

这不止是一份面试清单,更是一种”被期望的责任“,因为有无数个待面试者,希望从这篇文章中,找出通往期望公司的”钥匙“,所以上面每道选题都是结合我自身的经验于千万个面试题中经过艰辛的两周,一个题一个题筛选出来再次对好答案和格式做出来的,面试的答案也是再三斟酌,深怕误人子弟是小,影响他人仕途才是大过,也希望您能把这篇文章分享给更多的朋友,让他帮助更多的人,帮助他人,快乐自己,最后,感谢您的阅读。

由于细节内容实在太多啦,在这里我花了两周的时间把这些答案整理成一份文档了,在这里只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

16949)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-xcPlEOeW-1712800716949)]

结尾

[外链图片转存中…(img-Xpg8ZSTG-1712800716949)]

这不止是一份面试清单,更是一种”被期望的责任“,因为有无数个待面试者,希望从这篇文章中,找出通往期望公司的”钥匙“,所以上面每道选题都是结合我自身的经验于千万个面试题中经过艰辛的两周,一个题一个题筛选出来再次对好答案和格式做出来的,面试的答案也是再三斟酌,深怕误人子弟是小,影响他人仕途才是大过,也希望您能把这篇文章分享给更多的朋友,让他帮助更多的人,帮助他人,快乐自己,最后,感谢您的阅读。

由于细节内容实在太多啦,在这里我花了两周的时间把这些答案整理成一份文档了,在这里只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-XIihTEVI-1712800716949)]

  • 11
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值