十分鐘了結MySQL information_schema

来源:http://www.cnblogs.com/shengdimaya/archive/2017/05/30/6920677.html
-Advertisement-
Play Games

information_schema資料庫是MySQL系統自帶的資料庫,它提供了資料庫元數據的訪問方式。感覺information_schema就像是MySQL實例的一個百科全書,記錄了資料庫當中大部分我們需要了結的信息,比如字元集,許可權相關,資料庫實體對象信息,外檢約束,分區,壓縮表,表信息,索引 ...


information_schema資料庫是MySQL系統自帶的資料庫,它提供了資料庫元數據的訪問方式。感覺information_schema就像是MySQL實例的一個百科全書,記錄了資料庫當中大部分我們需要了結的信息,比如字元集,許可權相關,資料庫實體對象信息,外檢約束,分區,壓縮表,表信息,索引信息,參數,優化,鎖和事物等等。通過information_schema我們可以窺透整個MySQL實例的運行情況,可以了結MySQL實例的基本信息,甚至優化調優,維護資料庫等,可以說是真正的一部百科全書啊哈哈。 下麵就是根據自己學習的一些小小經驗將這些表進行一個大體的分類,方便大家了結,要是有不足的地方請指出,我會儘快修改。 1:關於字元集和排序規則相關的系統表 CHARACTER_SETS :存儲資料庫相關字元集信息(memory存儲引擎) COLLATIONS :字元集對應的排序規則 COLLATION_CHARACTER_SET_APPLICABILITY:就是一個字元集和連線校對的一個對應關係而已 下麵我們說一下character sets和collations的區別: 字元集(character sets)存儲字元串,是指人類語言中最小的表義符號。例如’A'、’B'等; 排序規則(collations)規則比較字元串,collations是指在同一字元集內字元之間的比較規則 每個字元序唯一對應一種字元集,但一個字元集可以對應多種字元序,其中有一個是預設字元序(Default Collation)  MySQL中的字元序名稱遵從命名慣例:以字元序對應的字元集名稱開頭;以_ci(表示大小寫不敏感)、_cs(表示大小寫敏感)或_bin(表示按編碼值比較)結尾。例如:在字元序“utf8_general_ci”下,字元“a”和“A”是等價的 看一下有關於字元集和校對相關的MySQL變數: character_set_server:預設的內部操作字元集 character_set_client:客戶端來源數據使用的字元集 character_set_connection:連接層字元集 character_set_results:查詢結果字元集 character_set_database:當前選中資料庫的預設字元集 character_set_system:系統元數據(欄位名等)字元集 再看一下MySQL中的字元集轉換過程: (1). MySQL Server收到請求時將請求數據從character_set_client轉換為character_set_connection; (2). 進行內部操作前將請求數據從character_set_connection轉換為內部操作字元集,其確定方法如下: 使用每個數據欄位的CHARACTER SET設定值; 若上述值不存在,則使用對應數據表的DEFAULT CHARACTER SET設定值(MySQL擴展,非SQL標準); 若上述值不存在,則使用對應資料庫的DEFAULT CHARACTER SET設定值; 若上述值不存在,則使用character_set_server設定值。 (3). 將操作結果從內部操作字元集轉換為character_set_results。 2:許可權相關的一些表: SCHEMA_PRIVILEGES:提供了資料庫的相關許可權,這個表是記憶體表是從mysql.db中拉去出來的。 TABLE_PRIVILEGES:提供的是表許可權相關信息,信息是從 mysql.tables_priv 表中載入的 COLUMN_PRIVILEGES :這個表可以清楚就能看到表授權的用戶的對象,那張表那個庫以及授予的是什麼許可權,如果授權的時候加上with grant option的話,我們可以看得到PRIVILEGE_TYPE這個值必須是YES。 USER_PRIVILEGES:提供的是表許可權相關信息,信息是從 mysql.user 表中載入的 通過表我們可以很清晰看得到MySQL授權的層次,SCHEMA,TABLE,COLUMN級別,當然這些都是基於用戶來授予的。可以看得到MySQL的授權也是相當的細密的,可以具體到列,這在某一些應用場景下還是很有用的,比如審計等。 3:存儲資料庫系統的實體對象的一些表: COLUMNS:存儲表的欄位信息,所有的存儲引擎 INNODB_SYS_COLUMNS :存放的是INNODB的元數據, 他是依賴於SYS_COLUMNS這個統計表而存在的。 ENGINES :引擎類型,是否支持這個引擎,描述,是否支持事物,是否支持分散式事務,是否能夠支持事物的回滾點 EVENTS :記錄MySQL中的事件,類似於定時作業 FILES :這張表提供了有關在MySQL的表空間中的數據存儲的文件的信息,文件存儲的位置,這個表的數據是從InnoDB in-memory中拉取出來的,所以說這張表本身也是一個記憶體表,每次重啟重新進行拉取。也就是我們下麵要說的INNODB_SYS_DATAFILES這張表。還要註意一點的是這張表包含有臨時表的信息,所以說和SYS_DATAFILES 這張表是不能夠對等的,還是要從INNODB_SYS_DATAFILES看。如果undo表空間也配置是InnoDB 的話,那麼也是會被記錄下來的。 PARAMETERS :參數表存儲了一些存儲過程和方法的參數,以及存儲過程的返回值信息。存儲和方法在ROUTINES裡面存儲。 PLUGINS :基本上是MySQL的插件信息,是否是活動狀態等信息。其實SHOW PLUGINS本身就是通過這張表來拉取道德數據 ROUTINES:關於存儲過程和方法function的一些信息,不過這個信息是不包括用戶自定義的,只是系統的一些信息。 SCHEMATA:這個表提供了實例下有多少個資料庫,而且還有資料庫預設的字元集 TRIGGERS :這個表記錄的就是觸發器的信息,包括所有的相關的信息。系統的和自己用戶創建的觸發器。 VIEWS :視圖的信息,也是系統的和用戶的基本視圖信息。 這些表存儲的都是一些資料庫的實體對象,方便我們進行查詢和管理,對於一個DBA來說,這些表能夠大大方便我們的工作,更快更方便的了結和查詢資料庫的相關信息。 4:約束外鍵等相關的一些表: REFERENTIAL_CONSTRAINTS:這個表提供的外鍵相關的信息,而且只提供外鍵相關信息 TABLE_CONSTRAINTS :這個表提供的是 相關的約束信息 INNODB_SYS_FOREIGN_COLS :這個表也是存儲的INNODB關於外鍵的元數據信息和SYS_FOREIGN_COLS 存儲的信息是一致的 INNODB_SYS_FOREIGN :存儲的INNODB關於外鍵的元數據信息和SYS_FOREIGN_COLS 存儲的信息是一致的,只不過是單獨對於INNODB來說的 KEY_COLUMN_USAGE:資料庫中所有有約束的列都會存下下來,也會記錄下約束的名字和類別 為什麼要把外鍵和約束單列出來呢,因為感覺這是一塊獨立的東西,雖然我們的生產環境大部分都不會使用外鍵,因為這會降低性能,但是合理的利用約束還是一個不錯的選擇,比如唯一約束。 5:關於管理的一些的一些表: GLOBAL_STATUS ,GLOBAL_VARIABLES,SESSION_STATUS,SESSION_VARIABLES:這四張表分別記錄了系統的變數,狀態(全局和會話的信息),作為DBA相信大家也都比較熟悉了,而且這幾張表也是在系統重啟的時候回重新載入的。也就是記憶體表。 PARTITIONS :MySQL分區表相關的信息,通過這張表我們可以查詢到分區的相關信息(資料庫中已分區的表,以及分區表的分區和每個分區的數據信息),分區相關詳細信息參見MySQL分區管理 PROCESSLIST:show processlist其實就是從這個表拉取數據,PROCESSLIST的數據是他的基礎。由於是一個記憶體表,所以我們相當於在記憶體中查詢一樣,這些操作都是很快的。 INNODB_CMP_PER_INDEXINNODB_CMP_PER_INDEX_RESET:這兩個表存儲的是關於壓縮INNODB信息表的時候的相關信息,有關整個表和索引信息都有.我們知道對於一個INNODB壓縮表來說,不管是數據還是二級索引都是會被壓縮的,因為數據本身也可以看作是一個聚集索引。關於壓縮表在information_schema系列十一有些許簡單的介紹。 INNODB_CMPMEM ,INNODB_CMPMEM_RESET:這兩個表是存放關於MySQL INNODB的壓縮頁的buffer pool信息,但是要註意一點的就是,用這兩個表來收集所有信息的表的時候,是會對性能造成嚴重的影響的,所以說預設是關閉狀態的。如果要打開這個功能的話我們要設置innodb_cmp_per_index_enabled參數為ON狀態。 INNODB_BUFFER_POOL_STATS :表提供有關INNODB 的buffer pool相關信息,和show engine innodb status提供的信息是相同的。也是show engine innodb status的信息來源。 INNODB_BUFFER_PAGE_LRU,INNODB_BUFFER_PAGE :維護了INNODB LRU LIST的相關信息,詳細請見小編筆記innodb buffer pool小解 INNODB_BUFFER_PAGE :這個表就比較屌了,存的是buffer裡面緩衝的頁數據。查詢這個表會對性能產生很嚴重的影響,千萬不要再我們自己的生產庫上面執行這個語句,除非你能接受服務短暫的停頓,詳細請見小編筆記innodb buffer pool小解 INNODB_SYS_DATAFILES :這張表就是記錄的表的文件存儲的位置和表空間的一個對應關係(INNODB) INNODB_TEMP_TABLE_INFO :這個表惠記錄所有的INNODB的所有用戶使用到的信息,但是只能記錄在記憶體中和沒有持久化的信息。 INNODB_METRICS :提供INNODB的各種的性能指數,是對INFORMATION_SCHEMA的補充,收集的是MySQL的系統統計信息。這些統計信息都是可以手動配置打開還是關閉的。有以下參數都是可以控制的:innodb_monitor_enable, innodb_monitor_disable, innodb_monitor_reset, innodb_monitor_reset_all。 INNODB_SYS_VIRTUAL :表存儲的是INNODB表的虛擬列的信息,當然這個還是比較簡單的,在MySQL 5.7中,支持兩種Generated Column,即Virtual Generated Column和Stored Generated Column,前者只將Generated Column保存在數據字典中(表的元數據),並不會將這一列數據持久化到磁碟上;後者會將Generated Column持久化到磁碟上,而不是每次讀取的時候計算所得。很明顯,後者存放了可以通過已有數據計算而得的數據,需要更多的磁碟空間,與實際存儲一列數據相比並沒有優勢,因此,MySQL 5.7中,不指定Generated Column的類型,預設是Virtual Column。 INNODB_CMP,INNODB_CMP_RESET:存儲的是關於壓縮INNODB信息表的時候的相關信息,詳細請見推薦筆記。 為什麼把這些表列為管理相關的表呢,因為我感覺像連接,分區,壓縮表,innodb buffer pool等表,我們通過這些表都能很清晰的看到自己資料庫的相關功能的狀態,特別是我們通過一些變數更容易窺透MySQL的運行狀態,方便我們進行管理。相關筆記有推薦innodb buffer pool小解MySQL分區管理information_schema系列十一。都是小編自己的筆記。 6:關於表信息和索引信息的一些表 TABLES,TABLESPACES,INNODB_SYS_TABLES ,INNODB_SYS_TABLESPACES : TABLES這張表毫無疑問了,就是記錄的資料庫中表的信息,其中包括系統資料庫和用戶創建的資料庫。show table status like 'test1'\G的來源就是這個表; TABLESPACES 卻是標註的活躍表空間。 這個表是不提供關於innodb的表空間信息的,對於我們來說並沒有太大作用,因為我們生產庫是強制INNODB的; INNODB_SYS_TABLES 這張表依賴的是SYS_TABLES數據字典中拉取出來的。此表提供了有關表格的格式和存儲特性,包括行格式,壓縮頁面大小位級別的信息(如適用) 提供的是關於INNODB的表空間信息,其實和SYS_TABLESPACES 中的INNODB信息是一致的。 STATISTICS:這個表提供的是關於表的索引信息,所有索引的相關信息。 INNODB_SYS_INDEXES:提供相關INNODB表的索引的相關信息,和SYS_INDEXES 這個表存儲的信息基本是一樣的,只不過後者提供的是所有存儲引擎的索引信息,後者只提供INNODB表的索引信息。 INNODB_SYS_TABLESTATS: 這個表就比較重要了,記錄的是MySQL的INNODB表信息以及索引查找使用的次數,其實就是MySQL資料庫的統計信息 這個表的記錄是記錄在記憶體當中的,是一個記憶體表,每次重啟後就會重新記錄,所以只能記錄從上次重啟後的資料庫統計信息。有了這個表,我們對於索引的維護就更加方便了,我們可以查詢索引的使用次數,方便清理刪除不常用的索引,提高表的更新插入等效率,節省磁碟空間。 INNODB_SYS_FIELDS :這個表記錄的是INNODB的表索引欄位信息,以及欄位的排名 INNODB_FT_CONFIG :這張表存的是全文索引的信息 INNODB_FT_DEFAULT_STOPWORD:這個表存放的是stopword 的信息,是和全文索引匹配起來使用的,和innodb的 INFORMATION_SCHEMA.INNODB_FT_DEFAULT_STOPWORD 是相同的,這個STOPWORD必須是在創建索引之前創建,而且必須指定欄位為varchar。stopword 也就是我們所說的停止詞,全文檢索時,停止詞列表將會被讀取和檢索,在不同的字元集和排序方式下,會造成命中失敗或者找不到此數據,這取決於停止詞的不同的排序方式。我們可以使用這個功能篩選不必要欄位。 INNODB_FT_INDEX_TABLE:這個表存儲的是關於INNODB表有全文索引的索引使用信息的,同樣這個表也是要設置innodb_ft_aux_table以後才能夠使用的,一般情況下是空的 INNODB_FT_INDEX_CACHE :這張表存放的是插入前的記錄信息,也是為了避免DML時候昂貴的索引重組 7:關於MySQL優化相關的一些表 OPTIMIZER_TRACE :提供的是優化跟蹤功能產生的信息.關於這個我也謝了做了一個小測試,MySQL追蹤優化器小試 PROFILING:SHOW PROFILE可以深入的查看伺服器執行語句的工作情況。以及也能幫助你理解執行語句消耗時間的情況。一些限制是它沒有實現的功能,不能查看和剖析其他連接的語句,以及剖析時所引起的消耗。 SHOW PROFILES顯示最近發給伺服器的多條語句,條數根據會話變數profiling_history_size定義,預設是15,最大值為100。設為0等價於關閉分析功能。詳細信息請見MySQL profile INNODB_FT_BEING_DELETED,INNODB_FT_DELETED: INNODB_FT_BEING_DELETED 這張表是INNODB_FT_DELETED的一個快照,只在OPTIMIZE TABLE 的時候才會使用。詳細信息詳見我的OPTIMIZE TABLE 小解 8:關於MySQL事物和鎖的相關的一些表 INNODB_LOCKS:現在獲取的鎖,但是不含沒有獲取的鎖,而且只是針對INNODB的。 INNODB_LOCK_WAITS:系統鎖等待相關信息,包含了阻塞的一行或者多行的記錄,而且還有鎖請求和被阻塞改請求的鎖信息等。 INNODB_TRX:包含了所有正在執行的的事物相關信息(INNODB),而且包含了事物是否被阻塞或者請求鎖。 我們通過這些表就能夠很方便的查詢出來未結束的事物和被阻塞的進程,這是不是更方便了,詳細可見information_schema系列八(事物,鎖)   最後如果大家有興趣的話,歡迎看我的隨筆information_schema系列,多多提提意見。如果感覺值得鼓勵,請點右下角推薦
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • PlistBuddy簡單使用 由於PlistBuddy並不在Mac預設的Path里,所以我們得通過絕對路徑來引用這個工具: 查看幫助 下麵我們來看看PlistBuddy的簡單使用 初始化一個 info.plist 文件 初始化info.plist 初始化info.plist 列印info.plist ...
  • BottomNavigationView是Google推出的底部導航欄組件,在沒有這些底部導航組件之前,Android開發者多使用的是RadioGroup,在上一個項目開發中我們使用了Google的BottomNaviationView與ViewPager相結合搭建了UI框架,現項目已經完成,總結如 ...
  • 最近才發現Study Jams China的官方論壇也支持MarkDown,所以就直接把筆記發在了那兒。 http://www.studyjamscn.com/thread 21855 1 1.html pid279318 ...
  • 伺服器端是與單片機連接的esp8266模塊,ip與port分別:192.168.4.1 333 android軟體的設計思路:打開無線網路,連上無線網路名字為“Backx”,的無線,連接成功後進行發送與接收線程;軟體也加了網路許可權,可是打開軟體連接時閃退。 ...
  • 課程3B的主要內容有:控制流、導航至其他App、支持其他語言(不是編程語言,是自然語言 :-D )、風格與主題。 ...
  • 第一篇 申請帳號 https://mp.weixin.qq.com/cgi-bin/registermidpage?action=index&lang=zh_CN 這裡註冊帳號,記得選小程式,不然其他都是之前的老功能不行的,我就遇到過坑。 記住郵箱只能使用一次,身份證只能綁定5次。好坑沒有找到解綁的 ...
  • Redis 小白指南(四)- 數據的持久化保存 簡介 因為 redis 將數據保存在記憶體中,很容易誘發的一個問題就是,程式崩潰或伺服器重啟等情況如何保證數據的正常存儲。 當我們以 redis 作為主資料庫使用時,或者將 redis 作為緩存伺服器使用時,在緩存被穿透後會對性能造成很大的影響,所有緩存 ...
  • Installating and Initializing a Greenplum Database System... 1 安裝說明 1.1 環境說明 1.2 集群說明 2 準備工作 2.1 Linux用戶 在所有節點上創建greenplum管理員用戶。 2.2 主機名和hosts配置 相同的配置 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...