四、一级缓存
五、二级缓存
一、Mybatis的Dao编写【mapper代理方式实现】
Mapper代理的开发方式,程序员只需要编写mapper接口(相当于dao接口)即可。Mybatis会自动的为mapper接口生成动态代理实现类。不过要实现mapper代理的开发方式****,需要遵循一些开发规范。****
1、mapper接口的全限定名要和mapper映射文件的namespace的值相同。 |
2、mapper接口的方法名称要和mapper映射文件中的statement的id相同。 |
3、mapper接口的方法参数只能有一个,且类型要和mapper映射文件中statement的parameterType的值保持一致。 |
4、mapper接口的返回值类型要和mapper映射文件中statement的resultType值或resultMap中的type值保持一致 |
第一步:重新写个UserMapper文件和定义mapper映射文件UserMapper.xml(内容同Users.xml,除了namespace的值),放到新创建的目录mapper下。 |
|
第二步:在全局配置文件中添加映射配置文件 |
|
第三步:测试 |
|
二、mybatis与hibernate的区别
1、通过直接编写SQL语句,可以直接对SQL进行性能的优化。 |
2、学习门槛低,学习成本低。只要有SQL基础,就可以学习mybatis,而且很容易上手。 |
3、由于直接编写SQL语句,所以灵活多变,代码维护性更好。 |
4、不能支持数据库无关性,即数据库发生变更,要写多套代码进行支持,移植性不好。 |
5、需要编写结果映射。 |
1、标准的orm框架,程序员不需要编 **需要zi料+ 绿色徽【vip1024b】** |
写SQL语句。
2、具有良好的数据库无关性,即数据库发生变化的话,代码无需再次编写。(以后,mysql数据迁移到oracle,只需要改方言配置)。
3、学习门槛高,需要对数据关系模型有良好的基础,而且在设置OR映射的时候,需要考虑好性能和对象模型的权衡。4、不能支持数据库无关性,即数据库发生变更,要写多套代码进行支持,移植性不好。5、程序员不能自主的去进行SQL性能优化。Mybatis应用场景:****
需求多变的互联网项目,例如电商项目。
Hibernate应用场景:****
需求明确、业务固定的项目,例如OA项目、ERP项目等。
三、延迟加载(懒加载)
延迟加载又叫懒加载,也叫按需加载。也就是说先加载主信息,在需要的时候,再去加载从信息。在mybatis中,resultMap标签 的association标签和collection标签具有延迟加载的功能。
总结
面试前的“练手”还是很重要的,所以开始面试之前一定要准备好啊,不然也是耽搁面试官和自己的时间。
我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。
面试题及解析总结
大厂面试场景
知识点总结
(img-0udda1S4-1710351462979)]
知识点总结
[外链图片转存中…(img-pkhtQCRy-1710351462980)]