当前位置: 首页 > news >正文

公司网站建设框架太原网络推广公司

公司网站建设框架,太原网络推广公司,后端开发是干什么的,网站要怎么做才能让360收录MyBatis 中的延迟加载是指在需要时才加载对象的某些属性或关联对象,而不是在初始查询时就加载所有数据。这对于性能优化和减少不必要的数据库查询非常有用。 1. 基于配置文件的延迟加载 在 MyBatis 的 XML 映射文件中,你可以使用 lazyLoadingEnabled 和…

MyBatis 中的延迟加载是指在需要时才加载对象的某些属性或关联对象,而不是在初始查询时就加载所有数据。这对于性能优化和减少不必要的数据库查询非常有用。

1. 基于配置文件的延迟加载

在 MyBatis 的 XML 映射文件中,你可以使用 lazyLoadingEnabledaggressiveLazyLoading 属性来配置延迟加载的行为。

  • lazyLoadingEnabled:设置为 true 启用延迟加载,默认为 false。当设置为 true 时,MyBatis 将延迟加载对象的属性。

  • aggressiveLazyLoading:设置为 true 时,MyBatis 会在任何可能的情况下延迟加载对象的属性。默认为 false。

开启方式
  • 方式1:全局设置,在mybatis-config.xml中进行开启
<!-- MyBatis 配置文件 -->
<configuration><settings><setting name="lazyLoadingEnabled" value="true"/><setting name="aggressiveLazyLoading" value="false"/></settings>
</configuration>
  • 方式2:局部设置,<association>和<collection>有个fetchType属性可以覆盖全局的懒加载状态:eager表示这个级联不使用懒加载要立即加载,lazy表示使用懒加载。
    <resultMap id="getUserById2Result" type="com.by.pojo.User">... ...<!--property="accountList":pojo的属性ofType="account":集合的泛型select="com.by.mapper.AccountMapper.selectAccountByUid":要调用的select标签的idcolumn="id":传递的参数fetchType="lazy":局部开启延迟加载--><collection property="accountList"ofType="account"select="com.by.mapper.AccountMapper.selectAccountByUid"column="id"fetchType="lazy"></collection></resultMap><select id="getUserById2" parameterType="int" resultMap="getUserById2Result">select * from user where id=#{id}</select>

2. 关联关系的延迟加载

在映射文件中,可以使用 <association><collection> 标签设置延迟加载。这样,在查询主对象时,关联对象的数据不会立即加载,只有在需要访问关联对象时才会执行额外的查询获取数据。

<!-- 用户表映射文件 UserMapper.xml -->
<select id="getUserWithOrders" resultMap="userWithOrders" parameterType="int">SELECT * FROM users WHERE id = #{userId}
</select><resultMap id="userWithOrders" type="User"><id property="id" column="id" /><!-- 其他用户属性 --><collection property="orders" ofType="Order" lazyLoad="true"><id property="orderId" column="order_id" /><!-- 其他订单属性 --></collection>
</resultMap>

3. 使用注解实现延迟加载

在 MyBatis 中也可以使用注解来实现延迟加载,例如使用 @Lazy 注解标注关联对象或集合。

public class User {private int id;private String username;@Lazyprivate List<Order> orders;// Getters and setters
}

注意事项

  • 延迟加载可以减少不必要的数据库查询,但如果不谨慎使用,可能会导致 N+1 查询问题(执行大量额外的查询)或者产生潜在的性能问题。
  • 使用延迟加载时,需要留意 Session 的生命周期。在对象加载时 Session 必须仍然处于打开状态,否则延迟加载可能会引发异常。

延迟加载是一个强大的特性,但需要根据实际情况谨慎使用,以确保在性能和数据一致性之间取得平衡。

http://www.khdw.cn/news/31305.html

相关文章:

  • 企业网站模板下载软件互联网营销师怎么考
  • 淘宝网页设计网站购物网站大全
  • 西安网站制作开发公司哪家好全网营销推广软件
  • 网站的pr百度浏览器网页
  • ui设计较好的网站seo外包
  • wordpress mp3seo流量优化
  • 做会计题目的网站2021近期时事新闻热点事件简短
  • 网站页面不更新营销渠道的概念
  • 网站建设建设价格网站怎么优化排名靠前
  • 怎么增加网站的外链培训心得体会范文500字
  • 网站建设后期收什么费用深圳疫情防控最新消息
  • 能免费做公务员题的网站北大青鸟培训机构靠谱吗
  • 推动高质量发展心得网站关键词优化排名软件系统
  • 北京市城乡建设和交通委员会网站今日小说排行榜
  • 汽车租赁网站怎么做杭州疫情最新消息
  • 摄影创意网站长沙网站seo收费
  • 长沙网站制作公司报价软文广告案例500字
  • 100款软件免费下载大全济南优化网络营销
  • 外贸网站建设 杭州长沙好的seo外包公司
  • 网购网站源代码seo建站系统
  • 网站的代理页面怎么做中文域名交易网站
  • 金华网站建设怎么弄属于自己的网站
  • wordpress网站费用厦门网站外包
  • 免费品牌网站制作营销策略有哪几种
  • 网站登陆界面怎么做百度竞价开户公司
  • 创业网站模板新手网络推广怎么干
  • 水立方建设集团有限公司网站济南百度竞价开户
  • 做网站的工作好做吗网站建设报价单模板
  • nike diy定制网站今日小说百度搜索风云榜
  • wordpress高德地图成都网站seo公司