久久一区二区三区精品-久久一区二区明星换脸-久久一区二区精品-久久一区不卡中文字幕-91精品国产爱久久久久久-91精品国产福利尤物免费

sql不為空怎么寫 因為一條SQL,我差

網絡 分享 時間: 收藏本文

sql不為空怎么寫 因為一條SQL,我差

sql空字符_sql不為空怎么寫_sql為空怎么寫

# 反常的 SQL 語句

我瞇開朦朧的雙眼,才發現剛才的發聲來源于我的組長莊哥,看到他在緊張的點開日志系統查看日志,我預感到有什么不妙的事情發生。

仔細一問才知道,原來就在我瞇眼的期間,線上數據庫服務器的 CPU 被打滿,同時觸發了生產數據庫只讀延遲的限定時間并且發出告警,而且告警的過程持續了半個小時。

這讓我倒吸了一口涼氣,因為我們組做的系統很多都用的是同一個數據庫服務器,日用戶活躍量有好幾十萬,如果服務器崩潰了將會使所有的系統服務都不可用。

于是我們趕緊通過 SQL 日志進行問題查找,最后排查出來是因為一張 SQL 的高量查詢沒有走索引導致。

日志列表顯示,這條 SQL 語句的掃描行數達到了上百萬,基本就是全表掃描的情況,而且半個小時的時間查詢了達上萬次,每條 SQL 查詢的耗時都在 以上。

我的天啊,難怪服務器會 CPU 打滿,這么一條耗時的 SQL 語句查詢量這么大,數據庫的資源當然是直接就崩潰了。

這是當時那條 SQL 的查詢情況:

sql空字符_sql為空怎么寫_sql不為空怎么寫

# 臨時處理

看了這條語句,我又倒吸一口涼氣,這不就是我寫的系統調用的 SQL 語句嗎?完了,這回逃不掉了,真是人在睡夢里,鍋從天上來。

sql空字符_sql不為空怎么寫_sql為空怎么寫

當然,因為是我自己寫的 SQL,所以我一看就知道這條語句是有問題的。

根據我的代碼處理,這條 SQL 的調用還少了個重要的參數 ,這個參數沒有傳的話是不應該走這條 SQL 查詢的。

在我的設計里,該參數是數據表里一個聯合索引的最左側字段,如果該字段沒有傳值的話,那么索引就不會生效了。

KEY?`idx_userfruitid_type`?(`user_fruit_id`,`task_type`,`receive_start_time`,`receive_end_time`)?USING?BTREE

雖然定位到了 SQL 語句,但是線上的問題刻不容緩,總不可能找出 Bug 改完再上線吧。

所以,我們只能做了一個臨時處理,就是在原來的表上多加了一個聯合索引,其實就是去掉了 字段,讓這些高量的查詢都能走新的索引。

就像下面這樣:

KEY?`idx_task_type_receive_start_time`?(`task_type`,`receive_start_time`,`receive_end_time`,`created_time`)?USING?BTREE

加上索引后,SQL 的掃描行數就大幅度的降低了,重啟實例后就又能正常運行了。

# 最左匹配原則

那么為什么最左側的字段沒傳索引就不生效了,這是因為 的聯合索引是基于“最左匹配原則”匹配的。

我們都知道,索引的底層是 B+ 樹結構,聯合索引的結構也是 B+ 樹,只不過鍵值數量不是一個,而是多個,構建一顆 B+ 樹只能根據一個值來構建,因此數據庫依據聯合索引最左的字段來構建 B+ 樹。

例如我們用兩個字段(name,age)這個聯合索引來分析:

sql空字符_sql不為空怎么寫_sql為空怎么寫

圖片來源于林曉斌老師的《 實戰 45 講》課程

當我們在 條件中查找 name 為“張三”的所有記錄的時候,可以快速定位到 ID4,并且查出所有包含“張三”的記錄。

而如果要查找“張三,10”這一條特定的數據,就可以用 name = "張三" and age = 10獲取。

因為聯合索引的鍵值對是兩個,所以只要前面的 name 確定的情況下就可以進一步定位到具體的 age 記錄。

但是如果你的查詢條件只有 age 的話,那么索引就不會生效,因為沒有匹配最左邊的字段,后面所有的索引字段都不會生效。

# 找出 Bug

雖然臨時做了處理,但問題并不算解決,很明顯是系統出現了 Bug 才會有走這樣的查詢條件。

因為是我自己寫的代碼,所以知道是哪條 SQL 后我就馬上定位到了代碼里的具體方法,后來才發現是因為我對 字段的判空處理不生效所致。

因為該字段是從調用方傳過來的,所以我在方法參數里對該字段做了非空限制的注解,也就是 包下的 @:

public class GardenUserTaskListReq implements Serializable {
private static final long serialVersionUID = -9161295541482297498L;
@ApiModelProperty(notes = "水果id") @NotNull(message = "水果id不能為空") private Long userFruitId; /**以下省略*/ .....................}

雖然加上該注解來做非空校驗,但我卻沒有在參數加上另一個注解 @。

該注解如果沒加上的話,那么調用 包下的校驗規則就都不生效,正確的寫法是在 層方法的參數前面加上注解:

sql為空怎么寫_sql空字符_sql不為空怎么寫

除此之外,因為 這個字段是另一張表的主鍵,我在代碼里也沒有對這張表是否存在這個 id 做查詢判斷。

這樣一來,無論調用方傳什么值過來都會直接觸發 SQL 查詢,并且在不跑索引的情況下直接走全表掃描。

sql空字符_sql不為空怎么寫_sql為空怎么寫

不得不說,這真是個低級錯誤,說真的,我對這個原因真是感到嘀笑皆非,再怎么說也工作幾年了,怎么還犯一些新手級別的錯誤呢,這臉打得真是讓我相當慚愧。

# 總結

雖然是低級錯誤,但造成的后果也算挺嚴重了,這次事件也讓我更加的警醒,在以后的開發工作中必須要遵守該有的原則,大概有這么幾點:

千里之堤毀于蟻穴,有時一個小 Bug 很容易就引發整個系統的崩盤,這一次的問題也讓我更加深刻的認識到了 代碼的重要性,不管業務開發的工作量有多麻煩,這一步操作絕對不能忽視。

相關專題 索引sql數據庫
信息流廣告 周易 易經 代理招生 二手車 網絡營銷 旅游攻略 非物質文化遺產 查字典 社區團購 精雕圖 戲曲下載 抖音代運營 易學網 互聯網資訊 成語 成語故事 詩詞 工商注冊 注冊公司 抖音帶貨 云南旅游網 網絡游戲 代理記賬 短視頻運營 在線題庫 國學網 知識產權 抖音運營 雕龍客 雕塑 奇石 散文 自學教程 常用文書 河北生活網 好書推薦 游戲攻略 心理測試 石家莊人才網 考研真題 漢語知識 心理咨詢 手游安卓版下載 興趣愛好 網絡知識 十大品牌排行榜 商標交易 單機游戲下載 短視頻代運營 寶寶起名 范文網 電商設計 免費發布信息 服裝服飾 律師咨詢 搜救犬 Chat GPT中文版 經典范文 優質范文 工作總結 二手車估價 實用范文 古詩詞 衡水人才網 石家莊點痣 養花 名酒回收 石家莊代理記賬 女士發型 搜搜作文 石家莊人才網 鋼琴入門指法教程 詞典 圍棋 chatGPT 讀后感 玄機派 企業服務 法律咨詢 chatGPT國內版 chatGPT官網 勵志名言 河北代理記賬公司 文玩 語料庫 游戲推薦 男士發型 高考作文 PS修圖 兒童文學 買車咨詢 工作計劃 禮品廠 舟舟培訓 IT教程 手機游戲推薦排行榜 暖通,電地暖, 女性健康 苗木供應 ps素材庫 短視頻培訓 優秀個人博客 包裝網 創業賺錢 養生 民間借貸律師 綠色軟件 安卓手機游戲 手機軟件下載 手機游戲下載 單機游戲大全 免費軟件下載 石家莊論壇 網賺 手游下載 游戲盒子 職業培訓 資格考試 成語大全 英語培訓 藝術培訓 少兒培訓 苗木網 雕塑網 好玩的手機游戲推薦 漢語詞典 中國機械網 美文欣賞 紅樓夢 道德經 標準件 電地暖 網站轉讓 鮮花 書包網 英語培訓機構 電商運營
主站蜘蛛池模板: 欧美日韩国产亚洲综合不卡 | 久久免费观看视频 | 波多野结衣中文视频 | 91久久精品一区二区三区 | 国产成人精品高清在线观看99 | 国产午夜精品一区二区三区不卡 | 免费看日韩欧美一级毛片 | 给我一个可以看片的www日本 | 婷婷亚洲久悠悠色在线播放 | 亚洲欧美综合国产精品一区 | 国产美女啪| 国产一起色一起爱 | 夜色视频一区二区三区 | 欧毛片 | 国产精品视频第一区二区三区 | 国产欧美一区二区精品久久久 | 免费99视频有精品视频高清 | 欧美日韩亚洲国产精品 | 黄色在线视频网 | 欧美一级特黄高清免费 | 亚洲国产高清在线 | 九九精品免视看国产成人 | 丝袜紧身裙国产在线播放 | 欧美不卡视频在线观看 | 亚洲视频在线免费播放 | 日韩久久中文字幕 | 成人午夜精品 | 日本www免费视频网站在线观看 | 久久综合伊人77777 | 女人张开腿让男人桶个爽 | japanese 色系 tube日本 | 国产亚洲精品一区二区久久 | 黄色美女视频网站 | 国产一在线精品一区在线观看 | 亚洲国产成人综合 | 国内精品久久久久久久久蜜桃 | 国产成人禁片免费观看视频 | 欧美日韩亚洲精品一区 | 亚洲一区二区三区影院 | 国产亚洲精品成人婷婷久久小说 | 中文精品视频一区二区在线观看 |