關於mysql的優化

来源:https://www.cnblogs.com/cdqblog/archive/2019/01/03/10214652.html
-Advertisement-
Play Games

MYSQL的優化一個很棘手的問題,也是一個公司最想處理得當的問題. 那麼今天,本人為大家帶來幾點優化資料庫的方法: 1.選取最適用的欄位屬性 一般來說,資料庫的的表越小,在其上面執行的查詢也會越快.因此,我們在設計表的時候可以將表中的寬度設的儘可能的小. 對於欄位來說,,我們儘量和值為NOT NUL ...


MYSQL的優化一個很棘手的問題,也是一個公司最想處理得當的問題.

  那麼今天,本人為大家帶來幾點優化資料庫的方法:

  1.選取最適用的欄位屬性

    一般來說,資料庫的的表越小,在其上面執行的查詢也會越快.因此,我們在設計表的時候可以將表中的寬度設的儘可能的小.

    對於欄位來說,,我們儘量和值為NOT NULL,這樣在查詢時,資料庫不用比較NULL值

    對於某些文本欄位,可以用ENUM類型來對該欄位下的數值進行限制.

  2.使用JOIN來代替子查詢

    瞭解mysql的人都知道,使用子查詢可以一次性的完成很多邏輯上的需要多個複雜步驟才能完成的SQL操作,但是這樣的查詢會大大降低查詢的速率

    如果使用JOIN來完成此項工作的話,速度會快很多.

    JOIN之所以效率很高.是因為MYSQL不需要在記憶體中創建臨時表來完成這個邏輯上的兩個步驟的查詢工作.

  3.UNION來代替手動創建的臨時表

    mysql從4.0版本開始支持聯合查詢.

    它可以把需要使用臨時表的兩條或更多的select查詢合併的一個查詢中,在客戶端的查詢會話結束的時候,臨時表會自動刪除

    從而保證資料庫整齊,高效.

  4.事務

    儘管使用子查詢,JOIN和UNION來創建各種查詢.但並不是所有的操作都可以用一條或幾條SQL語句就可以完成的

    為了防止資料庫出現意外.就要使用事務,推薦使用InnoDB引擎

    其作用是可以保持資料庫數據的一致性和完整性.

    另一個作用則是在多個用戶同時使用相同的數據源時,它可以鎖定資料庫的方法來為童虎提供一種安全的訪問方式

  5.鎖定表

    事務雖好,可由於它的獨占性,有時會影響資料庫的性能.假設有成千上萬的用戶同時訪問一個資料庫,就會產生比較嚴重的響應延遲

    那麼鎖定表,就可以起到維護數據完整性的作用,來獲得更好的性能.

  6.使用外鍵

    鎖定表也有它的弊端,那就是它不能保證數據的關聯性.這個時候,我們就可以使用外鍵.

    註意,引擎要用innodb而不是myisam類型

  7.使用索引

    索引是提高數據性能的常用方法,它可以令資料庫伺服器以比沒有索引快的多的速度檢索特定的行,尤其是在查詢語句中包含MAX(),MIN()和ORDER BY 這些命令的時候,性能提高更為明顯.

    一般來說,索引應建立在那些用於JOIN ,WHERE 判斷 和ORDER BY 排序的欄位上,儘可能不要對資料庫中某個含有大量重覆值的欄位建立索引.

  8.優化的查詢語句

    絕大多數下,用索引可以提高查詢的速度,但是如果SQL語句使用不恰當的話,索引將無法發揮作用.

    那麼該註意以下幾個方面:

      1.最好在相同類型的欄位間進行比較的操作

      2.在建有索引的欄位上儘量不要使用函數進行操作.

      3.在搜索字元型欄位時,我們有時會使用LIKE關鍵字和通配符,這種做法雖然簡單,但也是以犧牲系統性能為代價的操作.

    最後,應該註意避免在查詢中讓MYSQL進行自動類型轉換,因為轉換過程也會讓索引變得不起作用!

以上,就是我為大家總結的幾點關於優化資料庫的操作,僅供參考,若有雷同,實屬巧合!

                                                              ------作者 戀夏啊   2019-1-3


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 來,先複習一下,什麼是建模 昨天介紹了模型本質是對現實對象的抽象描述以及附帶的一整套抽象的方法;建模本質上就是建立現實對象和模型的一種映射關係. 今天我們走進模型空間,看看裡面最重要的是什麼 我們先來看看我們平時接觸最多的 感覺很高大上的 商業模型是什麼? 比如拿我們都知道的swot分析來看. 百科 ...
  • 更改用戶定義的資料庫角色註意事項 需具有以下一項或多項許可權或成員身份才能運行此命令: 對角色具有 ALTER 許可權 對資料庫具有 ALTER ANY ROLE 許可權 具有 db_securityadmin 固定資料庫角色的成員身份 此外,若要更改固定資料庫角色中的成員身份還需要: 具有 db_own ...
  • sql查詢 explain的詳細用法 操作時間:尋道時間+旋轉時間 引入索引:採用二叉樹結構 把第二列做為索引生成二叉樹結構,此時查詢89 只做了兩次io操作 但是mysql 為什麼不用二叉樹作為底層索引結構? 紅黑樹 hash where col1 > 6 如果使用哈希結構無法使用索引 mysql ...
  • --獲取JOB_NAMEselect * from DBA_DATAPUMP_JOBS;OWNER_NAME JOB_NAME OPERATION JOB_MODE STATE DEGREE ATTACHED_SESSIONS DATAPUMP_SESSIONS SYSTEM SYS_IMPORT_ ...
  • 登陸及查看: 常用數據類型: ...
  • 一、先到Oracle網站下載Instant Client 下載地址:http://www.oracle.com/technetwork/cn/database/features/instant client/index 092699 zhs.html 根據你的操作系統選擇不同的Instant Cli ...
  • 關鍵字的個數等於路的個數減1。 一個二叉樹節點可以存儲4kb大小的數據,假如關鍵字是整型的一個關鍵字占用4byte,其他數據冗餘4個位元組 4 kb = 4*1024 byte = 4096 byte。 4096/8 = 512 也就是說一個節點中可以存儲512個關鍵字。 多路平衡查找樹如何保證絕對的 ...
  • 一、創建表空間 在導入 dmp 文件之前,你要在資料庫裡面給它分配一片存儲它的地方(表空間)。 如果我們知道需要導入的資料庫的表空間直接創建就可以,如果不不知道,也沒有關係,我們可以用 txt 打開 dmp 文件,使用快捷鍵 Ctrl+F,查找 tablespace,就可以找到這個 dmp 文件所對 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...