目录
一、Mybatis的Dao编写【mapper代理方式实现】
二、mybatis与hibernate的区别
三、延迟加载(懒加载)
四、一级缓存
五、二级缓存
一、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框架,程序员不需要编写SQL语句。 |
2、具有良好的数据库无关性,即数据库发生变化的话,代码无需再次编写。(以后,mysql数据迁移到oracle,只需要改方言配置)。 |
3、学习门槛高,需要对数据关系模型有良好的基础,而且在设置OR映射的时候,需要考虑好性能和对象模型的权衡。 |
4、不能支持数据库无关性,即数据库发生变更,要写多套代码进行支持,移植性不好。 |
5、程序员不能自主的去进行SQL性能优化。 |
Mybatis应用场景:****
需求多变的互联网项目,例如电商项目。
Hibernate应用场景:****
需求明确、业务固定的项目,例如OA项目、ERP项目等。
三、延迟加载(懒加载)
延迟加载又叫懒加载,也叫按需加载。也就是说先加载主信息,在需要的时候,再去加载从信息。在mybatis中,resultMap标签 的association标签和collection标签具有延迟加载的功能。
UserMapper.java |
|
OdersMapper.java |
|
UserMappler.xml |
|
OrdersMapper.xml |
|
在全局配置文件中配置懒加载 |
|
测试 |
|
没有配置懒加载之前:即使不打印订单所属人的信息,也会执行查询订单所属人的sql语句。
配置懒加载后:只有在代码执行到打印所属人信息那一行时才会执行查询订单所属人的sql语句。
总结
无论是哪家公司,都很重视高并发高可用的技术,重视基础,重视JVM。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。
最后我整理了一些面试真题资料,技术知识点剖析教程,还有和广大同仁一起交流学习共同进步,还有一些职业经验的分享。
最后我整理了一些面试真题资料,技术知识点剖析教程,还有和广大同仁一起交流学习共同进步,还有一些职业经验的分享。
[外链图片转存中…(img-pdZEmE52-1721136931618)]