阿里开发规范禁止超过三张表 join,我们如何规避?

超过三张表的 JOIN 是否合适取决于具体的场景和需求。这里有几个方面可以考虑:

合适的场景

  1. 数据量小:如果参与 JOIN 的表数据量较小,且查询相对简单,那么即使是多表 JOIN 也不会带来明显的性能问题。
  2. 必须的业务需求:某些业务需求可能要求在一个查询中获取多张表的数据,这种情况下,多表 JOIN 是必要的。
  3. 数据库设计和优化:数据库的设计和索引优化良好,可以有效提高多表 JOIN 的性能。

不合适的场景

  1. 数据量大:当表的数据量很大时,多表 JOIN 可能导致查询速度变慢,影响系统性能。
  2. 复杂查询:多表 JOIN 会导致查询语句复杂,增加理解和维护的难度。
  3. 频繁查询:如果频繁进行多表 JOIN 操作,可能会导致数据库负载过重,影响其他操作。

优化策略

如果确实需要进行多表 JOIN,可以考虑以下优化策略:

  1. 索引优化:确保参与 JOIN 的列有适当的索引,以提高查询性能。
  2. 拆分查询:将一个复杂的多表 JOIN 查询拆分成多个简单的查询,然后在应用程序代码中合并结果。
  3. 使用视图:在数据库中创建视图,将复杂的多表 JOIN 封装在视图中,简化查询。
  4. 缓存:使用缓存机制存储频繁查询的结果,减少数据库查询的频率。
  5. 建表的时候做冗余设计:这样可能不符合数据库设计的范式,但实际开发中经常会这么操作。

实际应用中的示例(拆分查询)

在电子商务系统中,可能会遇到以下几种情况:

  1. 客户订单查询:需要查询客户的订单及其订单项和对应的产品信息。在这种情况下,超过三张表的 JOIN 是合理的,但需要注意性能优化。
  2. 统计分析:需要对多个表进行统计分析,此时可以考虑使用数据仓库或 OLAP(在线分析处理)系统来进行复杂查询,减少对事务性数据库的影响。

具体实现示例

假设我们在一个电子商务系统中,有 Orders、Customers、Products 和 OrderItems 四张表。我们需要查询某个客户的订单及其订单项和对应的产品信息。

// OrdersMapper
@Mapper
public interface OrdersMapper {@Select("SELECT * FROM Orders WHERE customer_id = #{customerId}")List<Order> selectByCustomerId(Long customerId);
}// OrderItemsMapper
@Mapper
public interface OrderItemsMapper {@Select("SELECT * FROM OrderItems WHERE order_id = #{orderId}")List<OrderItem> selectByOrderId(Long orderId);
}// ProductsMapper
@Mapper
public interface ProductsMapper {@Select("SELECT * FROM Products WHERE product_id = #{productId}")Product selectById(Long productId);
}// CustomersMapper
@Mapper
public interface CustomersMapper {@Select("SELECT * FROM Customers WHERE customer_id = #{customerId}")Customer selectById(Long customerId);
}// OrderService
@Service
public class OrderService {@Autowiredprivate OrdersMapper ordersMapper;@Autowiredprivate OrderItemsMapper orderItemsMapper;@Autowiredprivate ProductsMapper productsMapper;@Autowiredprivate CustomersMapper customersMapper;public List<OrderDTO> getOrdersByCustomerId(Long customerId) {List<OrderDTO> result = new ArrayList<>();List<Order> orders = ordersMapper.selectByCustomerId(customerId);Customer customer = customersMapper.selectById(customerId);for (Order order : orders) {OrderDTO orderDTO = new OrderDTO();orderDTO.setOrderId(order.getOrderId());orderDTO.setOrderDate(order.getOrderDate());orderDTO.setCustomerName(customer.getName());List<OrderItem> orderItems = orderItemsMapper.selectByOrderId(order.getOrderId());List<OrderItemDTO> orderItemDTOList = new ArrayList<>();for (OrderItem orderItem : orderItems) {Product product = productsMapper.selectById(orderItem.getProductId());OrderItemDTO orderItemDTO = new OrderItemDTO();orderItemDTO.setOrderItemId(orderItem.getOrderItemId());orderItemDTO.setProductName(product.getProductName());orderItemDTO.setQuantity(orderItem.getQuantity());orderItemDTO.setPrice(product.getPrice());orderItemDTOList.add(orderItemDTO);}orderDTO.setOrderItems(orderItemDTOList);result.add(orderDTO);}return result;}
}// OrderController
@RestController
@RequestMapping("/api/orders")
public class OrderController {@Autowiredprivate OrderService orderService;@GetMapping("/customer/{customerId}")public List<OrderDTO> getOrdersByCustomerId(@PathVariable Long customerId) {return orderService.getOrdersByCustomerId(customerId);}
}

通过这种方式,我们可以实现多表查询,同时注意查询的性能和复杂性。具体应用中需要根据业务需求和系统性能做出权衡和优化。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/387988.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于SpringBoot+Vue的企业客户信息反馈平台(带1w+文档)

基于SpringBootVue的企业客户信息反馈平台(带1w文档) 基于SpringBootVue的企业客户信息反馈平台(带1w文档) 企业客户信息反馈平台的开发运用java技术&#xff0c;MIS的总体思想&#xff0c;以及MYSQL等技术的支持下共同完成了该平台的开发&#xff0c;实现了企业客户信息反馈管…

【C++】哈希容器

unordered系列关联式容器 在之前的博文中介绍过关联式容器中的map与set&#xff0c;同map与set一样&#xff0c;unordered_set与unordered_set也是关联式容器。 在C98中&#xff0c;STL提供了底层为红黑树结构的一系列关联式容器&#xff0c;查询效率可以达到logN&#xff1b;在…

安装 Terraform for Tencent 使用

第一步 &#xff1a;下载安装包 前往 Terraform 官网&#xff0c;使用命令行直接安装 Terraform 或下载二进制安装文件。 解压并配置全局路径 Linux/MAC&#xff1a;export PATH$PATH:${可执行文件所在目录} 例如&#xff1a;export PATH$PATH:$/usr/bin/terraform Win…

vue2学习 -- 核心语法

文章目录 前置简介1. 模板语法2. 数据2.1 数据绑定2.2 el与data的两种写法2.3 MVVM模型2.4 Object.defineProperty2.5 Vue中的数据代理 3. 事件3.1 事件处理3.2 事件修饰符3.3 键盘事件 4. 计算属性5. 监视(侦听)属性5.1 书写形式5.2 深度监视5.3 简写形式5.4 计算属性和监听属…

Go语言生成excel、将excel保存到本地、将多个excel表格压缩为压缩包、在压缩文件上传OSS删除本地excel文件和压缩包

最近在公司了个需求&#xff0c;主要涉及到文件导出&#xff0c;需要根据特定表格文件生成excel文件导出&#xff0c;同时对导出的excel临时保存本地&#xff0c;生成压缩包&#xff0c;将压缩包上传至OSS&#xff08;Object Storage Service&#xff09;后删除本地临时文件。下…

Go+Redis零基础到用户管理系统API实战_20240730 课程笔记

概述 如果您没有Golang的基础&#xff0c;应该学习如下前置课程。 Golang零基础入门Golang面向对象编程Go Web 基础Go语言开发REST API接口_20240728Go语言操作MySQL开发用户管理系统API教程_20240729Redis零基础快速入门_20231227 基础不好的同学每节课的代码最好配合视频进…

AI绘画模型之:VAE、SD 与 SD-XL

重磅推荐专栏: 《大模型AIGC》 《课程大纲》 《知识星球》 本专栏致力于探索和讨论当今最前沿的技术趋势和应用领域,包括但不限于ChatGPT和Stable Diffusion等。我们将深入研究大型模型的开发和应用,以及与之相关的人工智能生成内容(AIGC)技术。通过深入的技术解析和实践经…

Linux常用工具

文章目录 tar打包命令详解unzip命令&#xff1a;解压zip文件vim操作详解netstat详解df命令详解ps命令详解find命令详解 tar打包命令详解 tar命令做打包操作 当 tar 命令用于打包操作时&#xff0c;该命令的基本格式为&#xff1a; tar [选项] 源文件或目录此命令常用的选项及…

19082 中位特征值

这个问题可以通过深度优先搜索&#xff08;DFS&#xff09;和优先队列来解决。我们首先使用DFS来计算每个节点的特征值&#xff0c;然后我们将所有节点的特征值放入一个优先队列中&#xff0c;然后我们从优先队列中取出中间的元素&#xff0c;这就是我们要找的中位数。 以下是…

如何选择合适的自动化测试工具!

选择合适的自动化测试工具是一个涉及多方面因素的决策过程。以下是一些关键步骤和考虑因素&#xff0c;帮助您做出明智的选择&#xff1a; 一、明确测试需求和目标 测试范围&#xff1a;确定需要自动化的测试类型&#xff08;如单元测试、集成测试、UI测试等&#xff09;和测试…

React-Native 宝藏库大揭秘:精选开源项目与实战代码解析

1. 引言 1.1 React-Native 简介 React-Native 是由 Facebook 开发的一个开源框架&#xff0c;它允许开发者使用 JavaScript 和 React 的编程模型来构建跨平台的移动应用。React-Native 的核心理念是“Learn Once, Write Anywhere”&#xff0c;即学习一次 React 的编程模型&am…

社区养老服务小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;服务人员管理&#xff0c;服务产品管理&#xff0c;服务预约管理&#xff0c;服务状态管理&#xff0c;服务退订管理&#xff0c;活动管理&#xff0c;视频管理 微信端账号功能包…

基于cubeMX的STM32的RTC实时时钟实现

1、在仪器仪表的项目开发中&#xff0c;时常需要设备显示当前的日期和时间&#xff0c;这时&#xff0c;可以使用STM32自带的RTC实时时钟模块来实现此功能。这里我们使用STM32F103RCT6单片机芯片为例。 2、cubeMX的设置 &#xff08;1&#xff09;RTC设置 &#xff08;2&…

民大食堂用餐小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;商家管理&#xff0c;档口号管理&#xff0c;商家餐品管理&#xff0c;餐品种类管理&#xff0c;购物车管理&#xff0c;订单信息管理 微信端账号功能包括&#xff1a;系统首页&a…

yolov10来了!用yolov10训练自己的数据集(原理、训练、部署、应用)

一、引言 YOLOv9还没热乎呢&#xff0c;YOLOv10就出来了&#xff0c;太卷了&#xff01;太快了&#xff01; 自今年2月YOLOv9发布之后&#xff0c; YOLO&#xff08;You Only Look Once&#xff09; 系列的接力棒传到了清华大学研究人员的手上。YOLOv10推出的消息引发了AI界的…

使用 Postman 进行 Trello API 自动化测试的完整指南

文章目录 前言一、自动化测试是什么&#xff1f;二、比较自动化测试与手工测试1. 自动化测试2. 手工测试 三、环境搭建1.创建Collection2.创建环境变量3.添加API请求 四、设计测试用例1. API简单调用2. 获取所有emoji3. 创建一个新看板&#xff1a;4. 获得创建的看板信息5. 在看…

安装nodejs服务器

Java项目可以运行在tomcat服务器&#xff0c;开始完成前后端完全分离。前端有自己独立的工程。我们需要把前端独立的工程运行起来。 运行在nodejs服务器下。 验证是否安装成功&#xff1a;敲cmd--输入node --version 1.安装npm java项目需要依赖jar,安装maven。前端项目也需要依…

Vitis HLS 完美嵌套循环通过 m_axi 接口读取DDR 的迭代次数细粒度控制实验 — 问题描述

1 自媒体账号 目前运营的自媒体账号如下&#xff1a; 哔哩哔哩 【雪天鱼】: 雪天鱼个人主页-bilibili.comCSDN 【雪天鱼】: 雪天鱼-CSDN博客 QQ 学习交流群 FPGA科研硕博交流群 910055563 (进群有一定的学历门槛&#xff0c;长期未发言会被请出群聊&#xff0c;主要交流FPG…

免费!OpenAI发布最新模型GPT-4o mini,取代GPT-3.5,GPT-3.5退出历史舞台?

有个小伙伴问我&#xff0c;GPT-4O mini是什么&#xff0c;当时我还一脸懵逼&#xff0c;便做了一波猜测&#xff1a; 我猜测哈&#xff0c;这个可能是ChatGPT4o的前提下&#xff0c;只支持文本功能的版本&#xff0c;速度更快 结果&#xff0c;大错特错。 让我们一起看看Open…

【简单介绍Gitea】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…