mybatis配置延迟加载和缓存.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
mybatis配置延迟加载和缓存

一. settings设置参数: 设置项描述允许值默认值cacheEnabled对在此配置文件下的所有cache 进行全 局性开/关设置。true | falsetruelazyLoadingEnabled全局性设置懒加载。如果设为‘关’, 则所有相关联的都会被初始化加载。true | falsetrueaggressiveLazyLoading当设置为‘开’的时候,懒加载的对象 可能被任何懒属性全部加载。否则,每 个属性都按需加载。true | falsetruemultipleResultSetsEnabled允许和不允许单条语句返回多个数据 集(取决于驱动需求)true | falsetrueuseColumnLabel使用列标签代替列名称。不用的驱动器 有不同的作法。参考一下驱动器文档, 或者用这两个不同的选项进行测试一 下。true | falsetrueuseGeneratedKeys允许JDBC 生成主键。需要驱动器支持。 如果设为了true,这个设置将强制使用 被生成的主键,有一些驱动器不兼容不 过仍然可以执行。true | falseFalseautoMappingBehavior指定MyBatis 是否并且如何来自动映射 数据表字段与对象的属性。PARTIAL 将只自动映射简单的,没有嵌套的结 果。FULL 将自动映射所有复杂的结果。NONE, PARTIAL, FULLPARTIALdefaultExecutorType配置和设定执行器,SIMPLE 执行器执 行其它语句。REUSE 执行器可能重复 使用prepared statements 语句,BATCH 执行器可以重复执行语句和批量更新。SIMPLE REUSE BATCHSIMPLEdefaultStatementTimeout设置一个时限,以决定让驱动器等待数 据库回应的多长时间为超时正整数Not Set (null) 二.mybatis的延迟加载? 延迟加载的意思是说,在关联查询时,利用延迟加载,先加载主信息。使用关联信息时再去加载关联信息。 要设置延迟加载,需要在SqlMapConfig.xml文件中,在settings标签中设置下延迟加载:lazyLoadingEnabled、aggressiveLazyLoading 代码演示如下: !-- 开启延迟加载 -- settings !-- lazyLoadingEnabled:延迟加载启动,默认是false -- setting name=lazyLoadingEnabled value=true / !-- aggressiveLazyLoading:积极的懒加载,false的话按需加载,默认是true -- setting name=aggressiveLazyLoading value=false / /settings 三.mybatis的缓存 许多应用程序,为了提高性能而增加缓存, 特别是从数据库中获取的数据.mybatis中对于缓存的使用,类似于hibernate的缓存机制,分为一级缓存和二级缓存 3.1 mybatis的一级缓存 mybatis的一级缓存是基于sqlSession的。 在同一个连接范围内,执行相同的查询SQL,第一次会去查询数据库,并写到缓存中;第二次直接从缓存中取。 当执行SQL时两次查询中间发生了增删改操作或者数据库连接关闭,则SqlSession的缓存清空。 与hibernate的一级缓存不一样,mybatis的一级缓存,可以用于所有的查询(hibernate中的一级缓存只针对根据主键查对象,而mybatis中查询全部时一级缓存也有效) 一级缓存的原理如下图: 3.2 mybatis的二级缓存 如果要实现 mybatis 的二级缓存,一般来说有如下两种方式: 1. 采用 mybatis 内置的 cache 机制。 2. 采用三方 cache 框架, 比如ehcache, oscache 等等. 3.2.1 mybatis内置的缓存机制 在 sql 语句映射文件中加入 cache / 语句 , 并且相应的实体类要实现 Serializable 接口,因为缓存说白了就是序列化与反序列化的过程,所以需要实现这个接口. 单纯的 cache / 表示如下意思: 1.所有在映射文件里的 select 语句都将被缓存。 2.所有在映射文件里 insert,update 和 delete 语句会清空缓存。 3.缓存使用“最近很少使用”算法来回收 4.缓存不会被设定的时间所清空。 5.每个缓存可以存储 1024 个列表或对象的引

文档评论(0)

haihang2017 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档