Mybatis核心知识点整理,常见面试题总结必备!

select * from t_user;

5.在mybatis-config.xml核心配置中注册mapper文件

9、Mybatis如何实现表单的增删改查?

1.添加一条数据

注意:生成主键策略还可以使用UUID的方式

insert into t_user(id,username,password) value(#{id},#{username},#{password});

2.更新一条数据

update t_user

username=#{username},

passsword=#{password}

3.删除一个数据

delete from t_user where id=#{id}

4.查询数据

select * from t_user;

10、Mybatis如何实现多个参数的接口方法(参数绑定)?

通过参数绑定,在UserDao的接口进行参数绑定

public User selectByUsernameAndUssername(@oaram(“username”) String username,@param(“password”)String password);

11、为什么要封装Mybatis工具类?

减少不必要的冗余,提高代码的可维护性

12、Struts2和Mybatis整合的步骤是什么?

1.引入相关jar包

(1)struts核心jar包及第三方依赖jar包

(2)Mybatis核心jar包,数据库的驱动jar包,log4.jar日志jar包

2.引入相关的配置文件

(1)struts首先在web.xml初始化配置中写Struts2.xml的核心过滤器,引入struts.xml核心配置文件

(2)Mybatis:mybatis-config.xml核心配置文件,XxxDaoMapper.xml配置文件

(3)jsbc.properties配置文件

(4)log4.properties日志配置文件

二、Mybatis进阶面试题


1、类型别名的好处及使用?

1.好处: 减少配置的冗余(对多次使用类型全名的位置进行简化书写)

2.使用:

在mybatis-config.xml中定义别名:

//type里面写实体类的目标位置

在mapper文件中使用别名:

2、使用别名后采用Mybatis开发Dao的实现步骤?

1.建表

2.开发相对应的实体类

3.实体类型别名的注册

  1. Dao接口的提取

  2. 使用XxxDaoMapper.xml实现Dao接口

  3. Mapper文件的注册

3、如何把提取mybatis-config.xml中数据库相关的参数?

1、把数据库连接相关的参数写在小配置文件中(jdbc.properties);

mysql版本:jdbc.properties放到src下

driver=com.mysql.cj.jdbc.Driver

url=jdbc:mysql://localhost:3306/db1?useSSL=false&serverTimezone=UTC

username=root

password=root

2、在mybatis-config.xml中引入小配置文件

3、使用${key}的形式替换原有的mybatis-config.xml配置文件的内容

4、ResultMapper的好处?

当查询的结果与实体类不匹配时(数据库的字段和实体类的属性不匹配),需要ResultMap进行处理

5、如何使用ResultMapper?

注意:针对单表的查询操作,可以使用取别名的方式简化开发,Result使用在多表查询操作中

6、Mybatis处理多表查询问题是什么?
  1. 表如何体现关系:通过外键

  2. 实体类如何维护关系:通过属性

  3. mapper文件如何实现dao:需要通过ResultMap映射一次

7、“一”的一方在mapper文件如何维护?

在mapper文件中使用标签,来维护“一”的一方的关系

select e.id as emp_id,

e.name as emp_name,

e.salary as emp_salary,

d.id as dep_id,

d.name as dep_name,

d.address as dep_address

from emp e

inner join dep d

on e.id = d.id

where e.id = #{id};

8、“多”的一方在mapper文件如何维护关系?

多的一方在mapper文件中使用Collection标签进行维护

select d.id,d.name,d.address,e.id,e.name,e.salary

from dep d

inner join emp e

on d.id = e.id

where d.id=#{id};

9,“多对多”的关系如何处理?

使用第三张表(中间表)维护多对多关系表的处理

实体的双方都加对方的集合类型属性

10、常见的动态Sql语句有哪些及作用?

sql动态片段:在mapper文件中如果需要书写多个相同的代码片段,对重复的一段sql进行提取,减少冗余

如: select * from

foreach:批量删除,批量查询操作

where:动态生成where查询语句

set:标签,动态修改,去除结尾不相关的,

trim:忽略sql语句末尾多余的关键字或者字符

11、foreach标签的作用是什么?

SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL。

  1. 针对(DML)操作,实现批处理

2、针对select操作,处理查询的条件是零散的数据

12、jdbcType的作用是什么?

读者福利

由于篇幅过长,就不展示所有面试题了,感兴趣的小伙伴

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

更多笔记分享

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

量查询操作

where:动态生成where查询语句

set:标签,动态修改,去除结尾不相关的,

trim:忽略sql语句末尾多余的关键字或者字符

11、foreach标签的作用是什么?

SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL。

  1. 针对(DML)操作,实现批处理

2、针对select操作,处理查询的条件是零散的数据

12、jdbcType的作用是什么?

读者福利

由于篇幅过长,就不展示所有面试题了,感兴趣的小伙伴

[外链图片转存中…(img-SnKynG6p-1714142125179)]

[外链图片转存中…(img-N8WZyZwg-1714142125180)]

[外链图片转存中…(img-keDN4sGV-1714142125180)]

更多笔记分享

[外链图片转存中…(img-DIyydBrC-1714142125180)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值