日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
MySQL8.0數(shù)據(jù)字典有什么變化

?1. MySQL 8.0數(shù)據(jù)字典有什么變化

我們提供的服務(wù)有:成都做網(wǎng)站、成都網(wǎng)站設(shè)計、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、棲霞ssl等。為上千余家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的棲霞網(wǎng)站制作公司

從MySQL 8.0開始,采用獨立表空間模式的每個InnoDB表只有一個 .ibd 表空間文件,而不再有 .frm 文件了。為了實現(xiàn)DDL的原子性,InnoDB直接把元數(shù)據(jù)存儲在表空間文件中,需要的話,可是使用 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 文件來記錄元數(shù)據(jù)信息。

在 .sdi 文件中,采用JSON格式存儲元數(shù)據(jù)信息。

對于MyISAM表,不能再像以前那樣,直接把 .frm\.MYD\.MYI 文件拷貝到目標(biāo)數(shù)據(jù)庫后就能直接用。方法改成了類似下面這樣的:

# 首先拷貝數(shù)據(jù)及索引文件到目標(biāo)數(shù)據(jù)庫
$ 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文檔中沒提到這點,但實測過程中發(fā)現(xiàn)需要加這步操作
$ vim $secure_file_priv/t1_1274.sdi
...
"schema_ref":"db1" #此處修改成 "schema_ref":"db2"
...

# 執(zhí)行導(dǎo)入操作
mysql> IMPORT TABLE FROM '$secure_file_priv/t1_1274.sdi';

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

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

2. 怎么查看每個/某個session里設(shè)置的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里修改成其他非默認設(shè)置值
| 29209 | sort_buffer_size | 4194304 |
+-----------+------------------+----------------+

再根據(jù) THREAD_ID? 列和 performance_schema.threads 關(guān)聯(lián)查詢,即可知道每個/某個session里的variables是否有自定義設(shè)置了。

3. mysqlpump備份并不好用

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


當(dāng)前文章:MySQL8.0數(shù)據(jù)字典有什么變化
瀏覽路徑:http://www.dlmjj.cn/article/cojgdds.html