2024年Java最新Mybatis核心知识点整理,常见面试题总结必备!(1),Java程序员需要掌握的知识

总结

三个工作日收到了offer,头条面试体验还是很棒的,这次的头条面试好像每面技术都问了我算法,然后就是中间件、MySQL、Redis、Kafka、网络等等。

  • 第一个是算法

关于算法,我觉得最好的是刷题,作死的刷的,多做多练习,加上自己的理解,还是比较容易拿下的。

而且,我貌似是将《算法刷题LeetCode中文版》、《算法的乐趣》大概都过了一遍,尤其是这本

《算法刷题LeetCode中文版》总共有15个章节:编程技巧、线性表、字符串、栈和队列、树、排序、查找、暴力枚举法、广度优先搜索、深度优先搜索、分治法、贪心法、动态规划、图、细节实现题

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

《算法的乐趣》共有23个章节:

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

  • 第二个是Redis、MySQL、kafka(给大家看下我都有哪些复习笔记)

基本上都是面试真题解析、笔记和学习大纲图,感觉复习也就需要这些吧(个人意见)

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

  • 第三个是网络(给大家看一本我之前得到的《JAVA核心知识整理》包括30个章节分类,这本283页的JAVA核心知识整理还是很不错的,一次性总结了30个分享的大知识点)

最新出炉,头条三面技术四面HR,看我如何一步一步攻克面试官?

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

需要这份系统化的资料的朋友,可以点击这里获取

4、Mybatis框架有哪些优点?

1.Mybatis自动将数据封装成实体

2.Mybatis提供缓存池,运行效率高

3.Mybtais提供级联查询

4.Mybatis使用XML对SQL语句进行操作,便于后续的维护

5、Mybatis的实现原理是什么?

mapper.xml实现dao层的接口,接口中的实现方法使用

,添加

,选择

,删除

>更新

6、如何搭建Mybatis的运行环境?

1.引入jar包

(1)核心jar包:MyBatis-3.2.2.jar

(2)第三方依赖:log4-1.2.17.jar

(3)数据库的驱动jar包

3.引入相关配置

(1)核心配置文件 mybatis-config.xml

(2)接口的实现使用XxxDaoMapper.xml

(3)做日志输出的配置文件log4j-1.2.17.jar

4.初始化配置

7、Mybatis的核心API有哪些?简述其作用?

1.Resouce 读取Mybatis的相关配置文件

2.sqlSessionFactoryBuilder:用于创建sqlSessionBuilder

3.sqlSessionFactory:用户创建(打开)sqlSession

4.sqlSession:

(1)控制事务 sqlSession.commit(); sqlSession.rollback();

(2)结合Mapper文件创建Dao接口的实现类

(3)在sqlSession封装了JDBC的connection接口,和Connection一一对应

(2)关闭连接SQLSession.close();

*注意:

1.sqlSessionFactory是重量级组件,线程安全,只创建一个sqlSessionFactory

2.增删改必须控制实现,查询不能控制事务,因为Mybatis的基于namespace的二级缓存的缓存池,释放缓存主要标志就是增删改!

8、采用Mybatis开发Dao的步骤有哪些?

1.建数据库表(t_user)

2.创建实体类(例如User)

3.创建Userdao的接口(查询所有的方法)

4.Mybatis中的Mapper.xml文件实现UserDao的接口

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,

总结

机会是留给有准备的人,大家在求职之前应该要明确自己的态度,熟悉求职流程,做好充分的准备,把一些可预见的事情做好。

对于应届毕业生来说,校招更适合你们,因为绝大部分都不会有工作经验,企业也不会有工作经验的需求。同时,你也不需要伪造高大上的实战经验,以此让自己的简历能够脱颖而出,反倒会让面试官有所怀疑。

你在大学时期应该明确自己的发展方向,如果你在大一就确定你以后想成为Java工程师,那就不要花太多的时间去学习其他的技术语言,高数之类的,不如好好想着如何夯实Java基础。下图涵盖了应届生乃至转行过来的小白要学习的Java内容:

请转发本文支持一下

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

需要这份系统化的资料的朋友,可以点击这里获取

p_salary,

总结

机会是留给有准备的人,大家在求职之前应该要明确自己的态度,熟悉求职流程,做好充分的准备,把一些可预见的事情做好。

对于应届毕业生来说,校招更适合你们,因为绝大部分都不会有工作经验,企业也不会有工作经验的需求。同时,你也不需要伪造高大上的实战经验,以此让自己的简历能够脱颖而出,反倒会让面试官有所怀疑。

你在大学时期应该明确自己的发展方向,如果你在大一就确定你以后想成为Java工程师,那就不要花太多的时间去学习其他的技术语言,高数之类的,不如好好想着如何夯实Java基础。下图涵盖了应届生乃至转行过来的小白要学习的Java内容:

请转发本文支持一下

[外链图片转存中…(img-IEX7uTCK-1714924061659)]

[外链图片转存中…(img-ne3Pa3Of-1714924061659)]

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

需要这份系统化的资料的朋友,可以点击这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值