news 2026/6/14 14:27:21

WITH AS vs 临时表:性能对比实测

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
WITH AS vs 临时表:性能对比实测

快速体验

  1. 打开 InsCode(快马)平台 https://www.inscode.net
  2. 输入框内输入如下内容:
创建性能对比测试脚本:1. 相同功能的WITH AS查询和临时表查询各一组 2. 包含执行计划分析 3. 不同数据量级(1万/100万/1000万行)的测试 4. 内存使用监控。使用Kimi-K2生成并自动执行测试,输出可视化对比图表。
  1. 点击'项目生成'按钮,等待项目生成完整后预览效果

今天在优化Oracle查询时,遇到了一个经典问题:使用WITH AS(公共表表达式)和临时表,哪种方式性能更好?为了找到答案,我决定做个系统测试。下面分享我的测试过程和发现,希望能帮到有同样疑问的朋友。

  1. 测试环境搭建 首先在InsCode(快马)平台创建了Oracle测试环境,这个平台的好处是能快速搭建数据库实例,省去了本地安装的麻烦。我准备了三组测试数据:1万行、100万行和1000万行,模拟不同规模的数据处理场景。

  2. 测试方案设计 测试对比两种实现方式:

  3. WITH AS子句:直接在查询中定义临时结果集
  4. 全局临时表:先创建临时表再插入数据

每组测试都包含相同的业务逻辑:多表关联、聚合计算和排序操作。为了确保公平性,每个测试都执行10次取平均值。

  1. 关键测试指标 主要监控四个维度:
  2. 查询执行时间
  3. 内存占用峰值
  4. 物理读写次数
  5. 执行计划差异

  6. 测试结果分析 在小数据量(1万行)时:

  7. WITH AS平均耗时0.8秒
  8. 临时表方案1.2秒
  9. WITH AS明显更快,因为避免了临时表的创建和写入开销

中等数据量(100万行)时: - WITH AS平均12秒 - 临时表9秒 - 临时表开始反超,因为Oracle优化器能更好利用临时表的统计信息

大数据量(1000万行)时: - WITH AS出现内存溢出 - 临时表稳定在110秒完成 - 临时表展现出更好的可扩展性

  1. 执行计划洞察 通过Kimi-K2生成的执行计划可视化发现:
  2. WITH AS会被多次物化,导致重复计算
  3. 临时表有更优的索引利用策略
  4. 复杂查询时临时表更容易获得稳定的执行计划

  5. 内存使用对比监控显示WITH AS在内存充足时很高效,但数据量大时容易成为瓶颈。临时表虽然初始开销大,但内存使用更平稳。

  6. 实践建议 根据测试结果,我总结出这些经验:

  7. 简单查询或小数据量优先用WITH AS
  8. 复杂查询或百万级以上数据用临时表
  9. 需要重复引用结果集时临时表优势明显
  10. 内存紧张的环境慎用WITH AS

  11. 优化技巧 如果必须使用WITH AS:

  12. 添加MATERIALIZE提示强制物化
  13. 限制结果集大小
  14. 避免在WITH子句中做复杂计算

对于临时表: - 预先创建好表结构 - 考虑添加适当索引 - 批量插入数据效率更高

这次测试让我深刻体会到,没有绝对的好坏,只有适合的场景。通过InsCode(快马)平台的便捷环境,我快速完成了这个性能对比实验。平台内置的Kimi-K2模型不仅能生成测试脚本,还能自动分析执行计划,大大提升了我的工作效率。特别是部署测试环境的过程特别顺畅,点几下就搞定了,省去了繁琐的配置工作。

实际使用中发现,平台编辑器对SQL语法支持很友好,有智能提示和错误检查,写复杂查询时特别有帮助。建议有类似性能优化需求的朋友,可以自己动手试试不同方案,数据会告诉你最佳选择。

快速体验

  1. 打开 InsCode(快马)平台 https://www.inscode.net
  2. 输入框内输入如下内容:
创建性能对比测试脚本:1. 相同功能的WITH AS查询和临时表查询各一组 2. 包含执行计划分析 3. 不同数据量级(1万/100万/1000万行)的测试 4. 内存使用监控。使用Kimi-K2生成并自动执行测试,输出可视化对比图表。
  1. 点击'项目生成'按钮,等待项目生成完整后预览效果
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/11 10:41:39

Rembg抠图模型压缩:轻量化部署实战

Rembg抠图模型压缩:轻量化部署实战 1. 智能万能抠图 - Rembg 在图像处理与内容创作领域,自动去背景(Background Removal)是一项高频且关键的需求。无论是电商商品图精修、社交媒体内容制作,还是AI生成图像的后处理&a…

作者头像 李华
网站建设 2026/6/14 6:25:33

Rembg模型评估:定量与定性分析方法

Rembg模型评估:定量与定性分析方法 1. 智能万能抠图 - Rembg 在图像处理领域,背景去除(Image Matting / Background Removal)是一项基础但极具挑战性的任务。传统方法依赖于用户手动标注、颜色阈值或边缘检测算法,不…

作者头像 李华
网站建设 2026/5/30 18:42:51

南大通用GBase 8s 内部用户创建及使用方法介绍

本文将详细介绍如何在 GBase 8s 中创建普通用户,并展示如何为这些用户赋权以及如何使用这些用户连接数据库。通过本文你将能够顺利地完成用户创建、赋权和连接数据库的全过程。探讨Gbase8S创建普通用户方法,直接执行 create user tmp_u001 with password…

作者头像 李华
网站建设 2026/5/30 11:28:55

GPUSTACK在深度学习训练中的实战应用

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个基于GPUSTACK的深度学习训练平台,支持多GPU并行训练和自动资源分配。平台应包含TensorFlow/PyTorch集成、训练进度监控和性能分析工具。实现自动扩展GPU资源功…

作者头像 李华
网站建设 2026/6/12 1:17:33

CentOS 7.9零基础入门:从安装到基本运维

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个CentOS 7.9新手学习环境,包含:1. 交互式安装引导 2. 常用命令练习场景 3. 基础服务(SSH/FTP)配置教程 4. 系统管理任务模拟 5. 实时帮助文档。要求…

作者头像 李华
网站建设 2026/6/4 2:45:07

对比传统开发:快马让STM32项目效率提升300%

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 请生成一个完整的STM32F407VG的USB HID设备项目,实现通过USB接口与PC通信,能够接收PC端发送的数据并控制开发板上的LED。要求:1) USB设备初始化…

作者头像 李华