MySQL 8.0數據字典有什麼變化

来源:https://www.cnblogs.com/greatsql/archive/2023/03/30/17271395.html
-Advertisement-
Play Games

GreatSQL社區原創內容未經授權不得隨意使用,轉載請聯繫小編並註明來源。 GreatSQL是MySQL的國產分支版本,使用上與MySQL一致。 作者: 葉金榮 文章來源:GreatSQL社區原創 1. MySQL 8.0數據字典有什麼變化 從MySQL 8.0開始,採用獨立表空間模式的每個Inn ...


  • GreatSQL社區原創內容未經授權不得隨意使用,轉載請聯繫小編並註明來源。
  • GreatSQL是MySQL的國產分支版本,使用上與MySQL一致。
  • 作者: 葉金榮
  • 文章來源:GreatSQL社區原創

1. MySQL 8.0數據字典有什麼變化

從MySQL 8.0開始,採用獨立表空間模式的每個InnoDB表只有一個 .ibd 表空間文件,而不再有 .frm 文件了。為了實現DDL的原子性,InnoDB直接把元數據存儲在表空間文件中,需要的話,可是使用 ibd2sdi 工具從中讀取,例如:

$ ibd2sdi test/t1.sdi
["ibd2sdi"
,
{
        "type": 1,
        "id": 1268,
        "object":
                {
    "mysqld_version_id": 80031,
    "dd_version": 80023,
    "sdi_version": 80019,
    "dd_object_type": "Table",
...
{
        "type": 2,
        "id": 29,
        "object":
                {
    "mysqld_version_id": 80031,
    "dd_version": 80023,
    "sdi_version": 80019,
    "dd_object_type": "Tablespace",
    "dd_object": {
        "name": "test/t1",
        "comment": "",
        "options": "autoextend_size=0;encryption=N;",
        "se_private_data": "flags=16417;id=24;server_version=80031;space_version=1;state=normal;",
        "engine": "InnoDB",
        "engine_attribute": "",
        "files": [
            {
                "ordinal_position": 1,
                "filename": "./test/t1.ibd",
                "se_private_data": "id=24;"
            }
        ]
    }
}
}
]

如果是MyISAM引擎表,也不再有 .frm文件,而是採用 .sdi 文件來記錄元數據信息。

在 .sdi 文件中,採用JSON格式存儲元數據信息。

對於MyISAM表,不能再像以前那樣,直接把 .frm.MYD.MYI 文件拷貝到目標資料庫後就能直接用。方法改成了類似下麵這樣的:

# 首先拷貝數據及索引文件到目標資料庫
$ cp -p ./db1/t1.MYD ./db1/t1.MYI ./db2

# 拷貝 .sdi 文件到 secure_file_priv 指定的路徑下
$ cp -p ./db1/t1_1274.sdi $secure_file_priv/

# 修改 .sdi 文件中的 schema 值,將 db1 改成 db2
# MySQL文檔中沒提到這點,但實測過程中發現需要加這步操作
$ vim $secure_file_priv/t1_1274.sdi
...
"schema_ref":"db1"  #此處修改成 "schema_ref":"db2"
...

# 執行導入操作
mysql> IMPORT TABLE FROM '$secure_file_priv/t1_1274.sdi';

上文中的 $secure_file_priv 需要自行替換成實際路徑。

另外,.sdi 文件名前面的數字,是該表的隱藏ID,每次新建一個表,這個值都會順序增加,類似 InnoDB 表的 TABLE_ID 值(這裡說的是類似,二者不等價)。

2. 怎麼查看每個/某個session里設置的variables

查看 performance_schema.variables_by_thread 即可

select * from variables_by_thread where VARIABLE_NAME = 'sort_buffer_size';
+-----------+------------------+----------------+
| THREAD_ID | VARIABLE_NAME    | VARIABLE_VALUE |
+-----------+------------------+----------------+
|     29310 | sort_buffer_size | 4194304        |
|     29375 | sort_buffer_size | 4194304        |
|     29378 | sort_buffer_size | 32768          |  -- 在這個session里修改成其他非預設設置值
|     29209 | sort_buffer_size | 4194304        |
+-----------+------------------+----------------+

再根據 THREAD_ID 列和 performance_schema.threads 關聯查詢,即可知道每個/某個session里的variables是否有自定義設置了。

3. mysqlpump備份並不好用

用mysqlpump備份時,預設是不會備份用戶授權信息的,需要類似這樣 mysqlpump --exclude-databases=% --users 單獨指定選項才能額外備份用戶授權信息。


Enjoy GreatSQL

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

-Advertisement-
Play Games
更多相關文章
  • 最近微軟總是各種掉鏈子,不是outlook有問題就是Teams出問題,辦公一點都不安生,Indians還真有些不靠譜。後來微軟正常後同事電腦的Teams卻出現問題,費了九牛二虎之力終於問題得到解決,特記錄步驟如下: teams登錄故障處理: 1.徹底清除卸載teams,刪除%appdat%\micr ...
  • 一:更新系統時間的方式 1、手動修改 通過相關工具來手動修改系統的時間。 2、自動同步 使用NTP自動同步系統時間。 二:手動修改系統時間 1、date工具 作用:顯示和設置系統時間 選項: -d <字元串> 顯示字元串所指的日期與時間,比如:"-1 day" 表示當前日期的前一天,必須要加雙引號 ...
  • OrientDB API v1.0.0(OrientDB 3.x) Gitee OrientDB介紹 OrientDB是一個開源的NoSQL資料庫管理系統,同時也是一款高性能的圖資料庫,支持ACID事務以及原子操作。 官網 圖資料庫介紹 圖資料庫是以點、邊為基礎存儲單元,以高效存儲、查詢圖數據為設計 ...
  • GreatSQL社區原創內容未經授權不得隨意使用,轉載請聯繫小編並註明來源。 GreatSQL是MySQL的國產分支版本,使用上與MySQL一致。 作者: 楊延昭 文章來源:GreatSQL社區投稿 在進行資料庫備份的時候主要分為了邏輯備份和物理備份這兩種方式。在數據遷移和備份恢復中使用mysqld ...
  • MySQL 1. 索引 1.1 什麼是索引 索引是一種特殊的文件(InnoDB數據表上的索引是表空間的一個組成部分),它們包含著對數據表裡所有記錄的引用指針。 索引是一種數據結構。資料庫索引,是資料庫管理系統中一個排序的數據結構,以協助快速查詢、更新資料庫表中數據。索引的實現通常使用B樹及其變種B+ ...
  • 摘要:應用業務模型ABM(Application Business Model)是MSSI為客戶提供的統一模型管理服務。 本文分享自華為雲社區《【雲圖說】 | 第274期 MSSI之應用業務模型ABM,搭建業務與技術的數據治理橋梁》,作者:閱識風雲。 應用業務模型ABM(Application Bu ...
  • 摘要:SSRF (Server-Side Request Forgery,伺服器端請求偽造)是指由攻擊者構造請求,然後利用伺服器的漏洞以服務端的身份向內網發送請求對內網發起攻擊。 本文分享自華為雲社區《GaussDB(DWS)安全測試之SSRF漏洞》,作者: ACBD。 1. 什麼是SSRF漏洞 S ...
  • 這篇主要描述了B端令牌系統應用數據分表解決業務數據量增大,且存在的數據傾斜問題,主要面向的場景是一對多數據傾斜問題 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...