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

哪里有网站开发定制wordpress 如何修改导航链接

哪里有网站开发定制,wordpress 如何修改导航链接,什么什么云用来做网站,阿里巴巴网站怎样做的漂亮引言 延迟加载是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/a/409598.html

相关文章:

  • 网页设计介绍北京网站产品展示网站系统
  • 一诺互联网站建设公司门户网站建设公司渠道
  • 黑龙江省建设教育信息网站做响应式网站设计
  • 重庆微信网站制作专家做钢材都有什么网站
  • 建设网站基础知识安卓一键制作app软件
  • 微信公众平台微网站开发企业网站管理源码
  • 南宁建设银行缴费网站iis 二级网站 发布
  • 2018网站做外链html课程
  • 给几个手机网站怎么做自动跳转网站
  • 网站开发外包网站玉林市建设局网站
  • 简述网站建设方法wordpress忘记用户名
  • 西安免费做网站电话wordpress导航跟随
  • 网站管理过程2 如何写一份详细的网站开发方案
  • 网站域名和备案公司可以不一样么建筑人才网简历
  • 景区网站建设材料用宝塔给远程网站做备份
  • 门源县电子商务网站建设公司运营推广公司
  • 网站所有权问题正规网络推广服务
  • 国内网站建设深圳短视频seo搜索排名如何做
  • 基层档案网站建设北京市建筑信息公开平台
  • 自己做网站还能挣钱吗湛江企业网站建设
  • 网站建设公司哪里找学校网站改版
  • 东莞公司网站制作要多少钱北极鱼wordpress
  • wordpress查询成绩seo泛站群
  • 南京网站开发联系南京乐识163邮箱官方注册入口
  • 网站做海外的防护广州网络公司有哪些
  • 环保主题的网站模板网站安全需做哪些监测
  • 网站开发需会的课程wordpress转typecho插件
  • 大型门户网站建设的意义织梦免费机械网站源码
  • 站长百科 wordpress免费网站模板 php
  • 英文网站 icp备案号可信网站认证代理