Before After:SQL整容級優化

首先說明這個優化有一定提升,但不是我所期望的

我接到一個涉及優化的SQL,具體內容實在太長。而且可能也不利于閱讀。于是我脫敏以及簡化一下。SQL中間大量的充斥著
(select 列名1
from t1
where t1.id = t2.id
) A,
(select 列名2
from t1
where t1.id = t2.id
) B,
(select 列名3
from t1
where t1.id = t2.id
) C,

這樣的的形式,如果配合實際的列,實際的表。那就太長了。洋洋灑灑數百行。

SQL最后是用到索引的,所以本次不是給索引方向的優化。

就上面的SQL而言,我和對方說,你這個就是t1和t2關聯,每一個字段都去關聯循環一次,這樣平白無故多做了很多次。其實把他放在一行一次性可以完成。這種時候一定要舉例。

拿一個樣品 A和B兩個表

image.png

模擬原始寫法是這樣的

image.png

那么我給的改寫建議是這樣的

image.png

從這兩個來說結果一致的,可以說基本是等效的。

那么看原始的執行效果

image.png

一共有三步access執行,最終發生了31次邏輯讀。

而改寫的執行效果

image.png

一共有兩步access執行,最終發生了14次邏輯讀。
畢竟我少一層括號。 而真實的SQL如果改寫了,那么就不是一層,那是幾十層了。

這背后的原因我是多少能猜出一點的

這些年站在開發角度看問題就習慣了。
就是需求提一個字段,加一個字段,那么就來一個括號。N表的聯合,每次多一個也不方便動之前的,就加吧。流水線作業,鐵打的代碼流水的開發。今天做完這個,明天還不一定做什么呢?
還有不少企業是外包做,那么就是雇傭兵,明天還在不在這里還一說呢。只管完成眼前任務。
當進度和質量沖突時候,保證進度。進度是影響收入的,質量不是。

最終一定是有優化作用

畢竟少了幾十個循環,一定是快了。而且SQL的篇幅是大幅降低。
當然還有一些其他方面的建議沒有達成一致。其實很多時候去管管不著調的需求,能有更好的收益。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/77114.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/77114.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/77114.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

道可云人工智能每日資訊|首屆世界人工智能電影節在法國尼斯舉行

道可云元宇宙每日簡報(2025年4月15日)訊,今日元宇宙新鮮事有: 杭州《西湖區打造元宇宙產業高地的扶持意見》發布 杭州西湖區人民政府印發《西湖區打造元宇宙產業高地的扶持意見》。該意見已于4月4日正式施行,有效期至…

JVM 為什么需要即時編譯器?

JVM之所以需要即時編譯器 (JIT Compiler),是為了提高 Java 程序的執行性能,彌補純解釋器執行的不足。 我們可以從以下幾個角度來分析一下這個問題: 1. 解釋器的性能瓶頸: 逐條解釋的開銷: 解釋器需要逐條讀取 Java 字節碼指令,并…

PromptUp 網站介紹:AI助力,輕松創作

1. 網站定位與核心功能 promptup.net 可能是一個面向 創作者、設計師、營銷人員及藝術愛好者 的AI輔助創作平臺,主打 零門檻、智能化的內容生成與優化。其核心功能可能包括: AI藝術創作:通過輸入關鍵詞、選擇主題或拖放模板,快速生成風格多樣的數字藝術作品(如插畫、海報…

ThingsBoard3.9.1 MQTT Topic(1)

1.網關轉發子設備的遙測信息, Topic:v1/gateway/telemetry { "m1": [{ "mode": "CW", "temperature": 23 }], "m2": [{ "mode": "CW", "temperature": 23 }] } 說明:json格式&a…

React 入門教程:構建第一個 React 應用

本教程將帶你從零開始構建你的第一個 React 應用。我們將創建一個簡單的計數器應用,涵蓋 React 的基本概念和開發流程。 準備工作 在開始之前,請確保你的開發環境滿足以下要求: Node.js (建議使用最新的 LTS 版本) npm 或 yarn (Node.js 安…

vue3中,element-plus中el-input的v-model和value的用法示例

el-input的v-model&#xff0c;邦定響應式變量 <el-col :span"6"><el-form-item label"檢驗類別" prop"verifyType"><el-input v-model"applyAllInfo.applyBasicInfo.verifyTypeName" readonly /></el-form-item…

策略模式隨筆~

若感行文枯燥&#xff0c;請移步至文末Gitee地址中查看源碼自行測試感受策略模式之魅力。 一、策略模式的核心概念 策略模式的定義 定義算法族&#xff0c;封裝每個算法&#xff0c;使其可互換。 核心三要素 Context&#xff1a;上下文&#xff0c;負責接收客戶端請求并委托…

Linux的目錄結構(介紹,具體目錄結構)

目錄 介紹 具體目錄結構 簡潔的目錄解釋 詳細的目錄解釋 介紹 Linux的文件系統是采用級層式的樹狀目錄結構&#xff0c;在此結構的最上層是根目錄“/”。Linux的世界中&#xff0c;一切皆文件&#xff08;比如&#xff1a;Linux會把硬件映射成文件來管理&#xff09; 具體目…

AWS CloudFront加速S3配置跨域

1、點擊分配 源我們就選擇S3–>選擇我們要加速的S3存儲桶 2、創建OAC訪問方式 在我們的來源訪問處–>來源訪問控制設置(推薦)–>選擇創建新的OAC(Create new OAC)–>自定義名字按默認選項保存–>選擇剛剛新創建的OAC 3、選擇查看器的配置 根據具體情況&#x…

進程控制(上)【Linux操作系統】

進程控制 寫時拷貝 本質是一種減少深拷貝的方法 Linux中有很多拷貝的場景都用得上寫時拷貝&#xff0c;下面以創建子進程時的寫時拷貝為例&#xff1a; 子進程被創建的時候&#xff1a; 會繼承父進程的mm_struct和頁表 所以子進程剛剛繼承時&#xff0c;父子進程的代碼和數據…

Flutter 強制橫屏

在 Flutter 中&#xff0c;可以通過設置 SystemChrome 來強制應用橫屏顯示。以下是實現這一功能的詳細步驟和代碼示例&#xff1a; 步驟 1&#xff1a;導入必要的包 確保在文件頂部導入了 services.dart 包&#xff0c;因為 SystemChrome 類位于該包中。 import package:flut…

Git完全指南:從入門到精通版本控制 ------- Git核心命令(6)

Git核心命令完全指南&#xff1a;從入門到高效協作 前言 在軟件開發領域&#xff0c;Git已成為現代版本控制的代名詞。據統計&#xff0c;全球超過90%的開發團隊使用Git進行代碼管理。然而&#xff0c;許多開發者僅停留在基礎命令的機械使用層面&#xff0c;未能真正掌握Git命…

關于Newtonsoft.Json

歷史 Newtonsoft.Json&#xff08;也稱為 Json.NET&#xff09;是由 James Newton - King 開發的一個開源的 JSON 處理庫&#xff0c;它于 2007 年首次發布。在早期&#xff0c;.NET 平臺缺乏一個強大且靈活的 JSON 處理工具&#xff0c;Newtonsoft.Json 應運而生&#xff0c;…

git reset詳解

一、git reset 的核心作用 用于 移動當前分支的 HEAD 指針 到指定的提交&#xff0c;并可選擇是否修改工作區和暫存區。 ?? 注意&#xff1a;若提交已被推送到遠程倉庫&#xff0c;強制重置&#xff08;--hard&#xff09;后需謹慎操作&#xff0c;避免影響協作。 二、三種模…

【unity游戲開發入門到精通——UGUI】CanvasScaler畫布縮放器組件

注意&#xff1a;考慮到UGUI的內容比較多&#xff0c;我將UGUI的內容分開&#xff0c;并全部整合放在【unity游戲開發——UGUI】專欄里&#xff0c;感興趣的小伙伴可以前往逐一查看學習。 文章目錄 一、CanvasScaler畫布縮放器組件是什么二、CanvasScaler的三種適配模式1、Cons…

Kubernetes控制平面組件:API Server Webhook 授權機制 詳解

云原生學習路線導航頁&#xff08;持續更新中&#xff09; kubernetes學習系列快捷鏈接 Kubernetes架構原則和對象設計&#xff08;一&#xff09;Kubernetes架構原則和對象設計&#xff08;二&#xff09;Kubernetes架構原則和對象設計&#xff08;三&#xff09;Kubernetes控…

Python自動化辦公

第五篇&#xff1a;Python自動化辦公&#xff1a;10行代碼搞定重復性工作 適合讀者&#xff1a;職場人士、數據分析師 | 閱讀時長&#xff1a;12分鐘 引言 每天重復處理Excel、PDF或郵件&#xff1f;Python可以幫你自動化這些枯燥任務&#xff0c;節省90%的時間。本文通過實際…

【3】k8s集群管理系列--包應用管理器helm之chart資源打包并推送到harbor鏡像倉庫

一、chart資源打包 helm package ./web-chart # 當前目錄會生成一個tgz的壓縮文件二、安裝help push插件&#xff08;用于推送前面打包的文件&#xff0c;到鏡像倉庫&#xff09; .1 下載help-push二進制文件 wget https://github.com/chartmuseum/helm-push/releases/down…

【SpringBoot Druid Mysql多數據源整合】

SpringBoot Druid Mysql多數據源整合 一、背景二、配置結果2.1 SpringBoot java 類配置2.1.1 啟動類配置2.1.2 java Config配置 2.2 SpringBoot yml 配置 三、mybatis插件配置3.1 PageHelper的yml配置3.2 mybatis設置自定義字段默認值 四、配置解釋 一、背景 公司項目需要連接另…

GGML源碼逐行調試(中)

目錄 前言1. 簡述2. 加載模型超參數3. 加載詞匯表4. 初始化計算上下文5. 初始化計算后端6. 創建模型張量7. 分配緩沖區8. 加載模型權重結語下載鏈接參考 前言 學習 UP 主 比飛鳥貴重的多_HKL 的 GGML源碼逐行調試 視頻&#xff0c;記錄下個人學習筆記&#xff0c;僅供自己參考&…