文章部分内容整理自郭永锋视频教学内容!
目录
一、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语句。
四、一级缓存
一级缓存指的就是sqlsession,在sqlsession中有一个数据区域,是map结构,这个区域就是一级缓存区域。一级缓存中的key是由sql语句、条件、statement等信息组成一个唯一值。一级缓存中的value,就是查询出的结果对象。
原理:
第一次查询id为1的用户,会执行sql语句,并将结果写入sqlsession一级缓存区域Map。
第二次查询id为1的用户,不会执行sql语句,而是从一级缓存中读取数据。
若在第一次和第二次查询之间执行了保存、删除、更新的操作,一级缓存将会消除,之后进行第二次查询id为1的用户又会执行sql语句。
五、二级缓存
二级缓存指的就是同一个namespace下的mapper,二级缓存中,也有一个map结构,这个区域就是二级缓存区域。二级缓存中的key是由sql语句、条件、statement等信息组成一个唯一值。二级缓存中的value,就是查询出的结果对象。一级缓存是默认使用的。二级缓存需要手动开启。
原理:
开启二级缓存总开关 |
|
UserMapper中配置二级缓存 |
|
User系列化 |
|
测试 |
|