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

网站模块制作seo网站推广平台

网站模块制作,seo网站推广平台,网站都是h5响应式,做儿童交互网站引言 延迟加载是MyBatis优化性能的核心技术之一&#xff0c;特别适用于处理对象关联关系。当主实体关联的子实体数据量较大或访问频率较低时&#xff0c;延迟加载能显著减少不必要的数据库查询&#xff0c;提升系统性能。完整代码实现 1. XML映射配置 <!-- 学生映射配置 --&…

引言

延迟加载是MyBatis优化性能的核心技术之一,特别适用于处理对象关联关系。当主实体关联的子实体数据量较大或访问频率较低时,延迟加载能显著减少不必要的数据库查询,提升系统性能。


完整代码实现

1. XML映射配置
<!-- 学生映射配置 -->
<resultMap id="studentMap" type="com.test.entity.Student"><id property="id" column="id"/><result property="name" column="name"/><association property="clazz" javaType="com.test.entity.Class"column="cid"select="com.test.repository.ClassRepository.findByClaId"/>
</resultMap><select id="findByStuId" parameterType="java.lang.Integer" resultMap="studentMap">SELECT * FROM student WHERE id = #{id}
</select><!-- 班级映射配置 -->
<select id="findByClaId" parameterType="java.lang.Integer" resultType="com.test.entity.Class">SELECT * FROM class WHERE id = #{id}
</select>
2. 仓库接口定义
// 学生仓库接口
public interface StudentRepository {Student findByStuId(Integer id);
}// 班级仓库接口
public interface ClassRepository {Class findByClaId(Integer id);
}

逐行解析配置

<resultMap id="studentMap" type="com.test.entity.Student">
  • <resultMap>:定义ORM映射规则
  • id="studentMap":映射规则唯一标识符
  • type="com.test.entity.Student":目标实体类全路径
<id property="id" column="id"/>
<result property="name" column="name"/>
  • <id>:主键字段映射(数据库id列 → 实体id属性)
  • <result>:普通字段映射(数据库name列 → 实体name属性)
<association property="clazz" javaType="com.test.entity.Class"column="cid"select="com.test.repository.ClassRepository.findByClaId"/>
  • property="clazz":映射到Student实体的clazz属性
  • javaType="com.test.entity.Class":关联属性的完整类型
  • column="cid":传递到关联查询的参数列(当前查询的cid字段值)
  • select="...":指定延迟加载的查询方法(关键配置)
<select id="findByStuId" resultMap="studentMap">SELECT * FROM student WHERE id = #{id}
</select>
  • 主查询:根据学生ID获取基本信息(不包含班级数据)

延迟加载执行流程

在这里插入图片描述


延迟加载核心特性

  1. 按需加载机制

    • 初始查询仅获取学生基础数据(不含关联对象)
    • 班级数据在首次调用getClazz()时动态加载
    • 避免不必要的数据传输和内存占用
  2. N+1查询模式

    • 1次主查询获取学生列表
    • N次关联查询获取每个学生的班级数据
    • 示例:查询10个学生 → 1(主查询)+10(班级查询)
  3. 关联查询分离

    • 主查询与关联查询完全解耦
    • 各查询可独立优化和复用
    • 通过select属性指定关联加载方法

延迟加载 vs JOIN查询

维度延迟加载JOIN查询
查询次数1 + N(按需加载)1次(复杂JOIN)
数据量首次响应快,传输量小单次传输量大
内存占用初始内存占用低一次性加载所有关联数据
适用场景关联数据访问率<30%需要立即使用所有关联数据
性能瓶颈N+1问题(批量操作时)JOIN复杂度
代码维护逻辑清晰,关联配置解耦SQL复杂度高

最佳实践与优化策略

1. 全局配置启用(mybatis-config.xml)
<settings><!-- 启用延迟加载 --><setting name="lazyLoadingEnabled" value="true"/><!-- 禁用激进加载 --><setting name="aggressiveLazyLoading" value="false"/><!-- 按需加载触发方法 --><setting name="lazyLoadTriggerMethods" value="equals,clone"/>
</settings>
2. 批量加载优化
<association property="clazz" select="com.test.repository.ClassRepository.findById"fetchType="lazy"  <!-- 显式声明加载方式 -->column="cid"/>
3. 解决N+1问题
  • 批量预加载:通过@Fetch注解配置批量加载
    @Fetch(FetchMode.SUBSELECT)
    private Class clazz;
    
  • 智能判断:根据业务场景混合使用JOIN和延迟加载
  • 二级缓存:对频繁访问的关联实体启用缓存
4. 方法命名规范

如示例所示,采用findByStuId/findByClaId的明确命名:

  • 清晰区分主查询和关联查询
  • 避免方法重载导致的歧义
  • 提高代码可读性和维护性

典型应用场景

  1. 列表-详情页模式

    • 列表页:仅加载学生基本信息(findByStuId
    • 详情页:点击时加载班级数据(触发getClazz()
  2. 大对象关联

    • 学生关联班级简历(大文本字段)
    • 初始不加载,需要时再获取
  3. 多级嵌套关联

    学生
    班级
    班主任
    教研组

    逐级延迟加载避免深度JOIN

  4. 微服务架构

    • 学生服务和班级服务分离时
    • 通过延迟加载实现跨服务数据聚合

总结

MyBatis延迟加载通过精妙的<association>配置和按需加载机制,在保证功能完整性的同时优化了系统性能。关键点在于:

  1. 使用select属性分离关联查询
  2. 通过明确的方法命名(如findByXxxId)增强可读性
  3. 合理配置全局延迟加载策略
  4. 根据业务场景选择加载策略(延迟加载/JOIN/批量加载)

正确使用延迟加载可使应用在数据层获得10x性能提升,特别适用于大型企业级应用和高并发场景。

http://www.dtcms.com/wzjs/25650.html

相关文章:

  • 切图做网站如何做企业网站设计公司
  • 网站改版 网站存在问题百度竞价推广自己可以做吗
  • 小说类网站怎么做微博营销推广策划方案
  • 网站建设思企互联2022推广app赚佣金平台
  • 个人接做网站多少钱可以推广赚钱的软件
  • 淘客网站怎么做排名百度推广价格
  • 如何重建网站网站的友情链接是什么意思
  • 网站建设赚钱项目创量广告投放平台
  • 公司网站建设做分录广告投放这个工作难不难做
  • 猎头自己在哪个网站做单怎样在平台上发布信息推广
  • 代做网站地图深圳sem竞价托管
  • 做网站什么笔记本好用制作网页的步骤
  • 日本真人做的视频网站厦门人才网唯一官网招聘
  • 麻涌仿做网站职业培训热门行业
  • 设计网站建十大经典事件营销案例
  • 如何评判一个网站建设的怎么样营销型网站的类型有哪些
  • 付费做SPaSS统计分析的网站超级软文
  • 微信上的网站怎么做的吗营销渠道的概念
  • 个人网站备案入口销售网站
  • 山西企业建站系统平台怎样做网络销售平台
  • 买空间的网站好湖北seo
  • 高端网站开发的公司电话销售怎么找客户渠道
  • 泊头市有做网站的吗昆明优化网站公司
  • 谷歌推广网站建设网络搜索优化
  • 计算机网络网站开发软文推广系统
  • 给个网站做导航违法吗seo和网络推广有什么区别
  • 广州微网站建设效果百度文库网页版登录入口
  • dede做购物网站希爱力吃一颗能干多久
  • 济南网站建设专业竞价关键词排名软件
  • 网站如何做外链教程视频舆情网站直接打开的软件