切換語言為:簡體

SQL中為什麼不要使用1=1?

在工作中的老專案中經常會看到程式碼中使用了1=1的情況,想起來之前自己也這個樣子寫過,感覺也沒有啥影響就沒有當回事,隨著工作年限,工作經驗的增加,對著一塊有了更深的理解,下面我們就來看一看程式碼開發中,編寫SQL語句其實就和家常炒菜差...

InnoDB 行鎖分類解讀

InnoDB 行鎖分類解讀

行級鎖每次操作均會鎖定對應的行資料,鎖定粒度最小,致使鎖衝突發生的可能性最低,因而併發度最高。它被應用於 InnoDB 儲存引擎之中,要知道,InnoDB 的資料是依據索引來組織的,行鎖透過對索引上的索引項加鎖來實現,並非針對記錄加鎖...

在 MAC 中 MySQL 從安裝到使用全過程

可以將這篇文章完善為一個完整的教程,涵蓋從安裝 MySQL 到使用 Navicat 和 Node.js 進行資料庫操作的全過程。以下是最佳化和擴充套件後的文章內容:MySQL 資料庫全流程指南本文將詳細介紹如何在 macOS 上安裝 ...

mysql 的RedoLog和BinLog區別

MySQL中的重做日誌(Redo Log)和二進制日誌(Binary Log)是兩種重要的日誌系統,它們在資料庫的事務處理、恢復和複製中扮演著關鍵角色。不知道為啥面試官總是喜歡問這個問題,搞明白它成為必然,,來,一起分析一下它們之間的...

記住,Mysql在建立索引時不一定會鎖表!

記住,Mysql在建立索引時不一定會鎖表!

索引主要是用於提高資料檢索速度的一種機制,透過索引資料庫可以快速定位到目標資料的位置,而不需要遍歷整個資料集,它就像書籍的目錄部分,有它的存在,可以大大加速查詢的效率。那麼問題來了:在建立索引時一定會鎖表嗎?如果你看的是網上的一些資料...

MVCC 是如何保持資料一致性的

MVCC(Multi-Version Concurrency Control)是一種併發控制機制,用於解決資料庫併發訪問中,資料一致性問題。它透過在讀寫操作期間儲存多個數據版本,以提供併發事務間的隔離性,從而避免了傳統的鎖機制所帶來的...

線上擁有大資料量資料庫 MySQL 如何高效率的更新表結構

線上擁有大資料量資料庫 MySQL 如何高效率...

在我最近的專案中,經常會有給大表加欄位的需求,這個過程非常耗時。可以看到,900 萬資料量的一張表,加一個欄位就需要 3 個小時左右。我們知道,給一個表加欄位,或者修改欄位,或者加索引,需要掃描全表的資料。假設表資料量比較大,加欄位的...

Mysql 的後設資料鎖

Mysql 的後設資料鎖

什麼是後設資料鎖?英文名叫Metadata Lock,縮寫為MDL,顧名思義,它是針對後設資料的一種鎖,鎖的是後設資料。那什麼是後設資料?一張表有100條記錄,這裏的記錄我們可以稱之為表資料,一張表的名字叫t1,有c1、c2兩個欄位,...

MySQL 效能調優的三個方向

MySQL 資料庫是一個廣泛使用的關係型資料庫管理系統,在日常開發和生產環境中,資料庫的效能直接影響到系統的穩定性和響應速度。爲了保證資料庫高效執行,MySQL 效能調優和 SQL 調優是必不可少的。本文將深入探討 MySQL 的效能...

MySQL和 Oracle 以及 SQL Server 有哪些區別?

MySQL和 Oracle 以及 SQL Se...

SQL Server、Oracle 和 MySQL 是三種廣泛使用的關係型資料庫管理系統(RDBMS),它們在功能、架構、效能和適用場景上都有顯著的區別。本文將深入探討這些差異,幫助大家更好地理解這三種資料庫系統,併爲實際應用中的選擇...

MySQL多長時間需要全量備份,多長時間需要增...

在實際生產環境中,MySQL資料庫的備份策略是確保資料安全性和高可用性的重要環節。備份策略的制定需要考慮多個因素,包括資料的重要性、資料變更的頻率、系統資源、恢復時間目標(RTO)和恢復點目標(RPO)等。以下是關於MySQL全量備份...

SQL 調優最佳實踐

寫作背景網上一直在說 SQL 調優,到底什麼是 SQL 調優?是不是覺得自己知道但又很模糊說不清楚,面試被問沒有真實的案例,並不具備說服力。本文以為詳細案例給大家解讀。開始之前,先回答什麼是 SQL 調優,SQL 調優是爲了讓 SQL...