最后
针对以上面试题,小编已经把面试题+答案整理好了
面试专题
除了以上面试题+答案,小编同时还整理了微服务相关的实战文档也可以分享给大家学习
🍅 程序员小王的博客:https://www.wolai.com/wnaghengjie/ahNwvAUPG2Hb1Sy7Z8waaF
🍅 扫描主页左侧二维码,加我微信 一起学习、一起进步
🍅 欢迎点赞 👍 收藏 ⭐留言 📝
=================================================================================
1、Mybatis框架是什么?
Mybatsi框架是一个数据库持久层的框架,用于对数据库的访问和操作。即Mybatis用于封装JDBC解决Dao的通用问题
2、什么是ORM思想?
对象关系映射,通过面向对象的思想完成对数据库的操作,具体映射如下:
| 一张表 | 一个实体类 |
| — | — |
| 列(属性) | 属性 |
| 一条语句 | 一个操作数据库的Dao方法 |
| 一条具体的数据 | 一个具体的实际对象 |
3、原始JDBC开发存在什么问题?
- 不能自动完成数据库表与实体对象的映射,产生大量冗余代码
2、没有连接池和缓存,运行效率低
3、JDBC查询关系比较繁琐
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日志配置文件
1、类型别名的好处及使用?
1.好处: 减少配置的冗余(对多次使用类型全名的位置进行简化书写)
2.使用:
在mybatis-config.xml中定义别名:
//type里面写实体类的目标位置
在mapper文件中使用别名:
2、使用别名后采用Mybatis开发Dao的实现步骤?
1.建表
2.开发相对应的实体类
3.实体类型别名的注册
-
Dao接口的提取
-
使用XxxDaoMapper.xml实现Dao接口
-
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?
结尾
这不止是一份面试清单,更是一种”被期望的责任“,因为有无数个待面试者,希望从这篇文章中,找出通往期望公司的”钥匙“,所以上面每道选题都是结合我自身的经验于千万个面试题中经过艰辛的两周,一个题一个题筛选出来再次对好答案和格式做出来的,面试的答案也是再三斟酌,深怕误人子弟是小,影响他人仕途才是大过,也希望您能把这篇文章分享给更多的朋友,让他帮助更多的人,帮助他人,快乐自己,最后,感谢您的阅读。
由于细节内容实在太多啦,在这里我花了两周的时间把这些答案整理成一份文档了,在这里只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!
rthday1">
结尾
[外链图片转存中…(img-hnL9O9Me-1714924087522)]
这不止是一份面试清单,更是一种”被期望的责任“,因为有无数个待面试者,希望从这篇文章中,找出通往期望公司的”钥匙“,所以上面每道选题都是结合我自身的经验于千万个面试题中经过艰辛的两周,一个题一个题筛选出来再次对好答案和格式做出来的,面试的答案也是再三斟酌,深怕误人子弟是小,影响他人仕途才是大过,也希望您能把这篇文章分享给更多的朋友,让他帮助更多的人,帮助他人,快乐自己,最后,感谢您的阅读。
由于细节内容实在太多啦,在这里我花了两周的时间把这些答案整理成一份文档了,在这里只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!