91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql表碎片的查詢自己回收

發布時間:2020-07-22 22:52:01 來源:網絡 閱讀:2106 作者:被啃的窩瓜 欄目:MySQL數據庫

MySQL中,我們經常會使用VARCHARTEXTBLOB等可變長度的文本數據類型。不過,當我們使用這些數據類型之后,我們就不得不做一些額外的工作——MySQL數據表碎片整理。
每當MySQL從你的列表中刪除了一行內容,該段空間就會被留空。而在一段時間內的大量刪除操作,會使這種留空的空間變得比存儲列表內容所使用的空間更大。

當MySQL對數據進行掃描時,它掃描的對象實際是列表的容量需求上限,也就是數據被寫入的區域中處于峰值位置的部分。如果進行新的插入操作,MySQL將嘗試利用這些留空的區域,但仍然無法將其徹底占用。


1.或者查看某個表所占空間,以及碎片大小。

select table_name,engine,table_rows,data_length+index_length length,DATA_FREE from information_schema.tables where TABLE_SCHEMA='test';

或者

select table_name,engine,table_rows,data_length+index_length length,DATA_FREE from information_schema.tables where data_free !=0;


+------------+--------+------------+--------+-----------+
| table_name | engine | table_rows | length | DATA_FREE |
+------------+--------+------------+--------+-----------+
| curs       | InnoDB |          0 |  16384 |         0 |
| t          | InnoDB |         10 |  32768 |         0 |
| t1         | InnoDB |          9 |  32768 |         0 |
| tn         | InnoDB |          7 |  16384 |         0 |
+------------+--------+------------+--------+-----------+

table_name 表的名稱
engine :表的存儲引擎
table_rows  表里存在的行數
data_length 表的大小(表數據+索引大小)
DATA_FREE :表碎片的大小
以上單位都是byte字節

整理碎片:
整理碎片過程會鎖邊,盡量放在業務低峰期做操作

1、myisam存儲引擎回收碎片
optimize table aaa_safe,aaa_user,t_platform_user,t_user;
2、innodb存儲引擎回收碎片
alter table t engine=innodb;

1.MySQL官方建議不要經常(每小時或每天)進行碎片整理,一般根據實際情況,只需要每周或者每月整理一次即可。

2.OPTIMIZE TABLE運行過程中,MySQL會鎖定表。
4.默認情況下,直接對InnoDB引擎的數據表使用
OPTIMIZE TABLE

腳本回收innodb表碎片 

#!/bin/bash

DB=test

USER=root

PASSWD=root123

HOST=192.168.2.202

MYSQL_BIN=/usr/local/mysql/bin

D_ENGINE=InnoDB

$MYSQL_BIN/mysql -h$HOST -u$USER -p$PASSWD $DB -e "select TABLE_NAME from information_schema.TABLES where TABLE_SCHEMA='"$DB"' "';" | grep -v "TABLE_NAME" >tables.txt

for t_name in  `cat tables.txt`

do

    echo "Starting table $t_name......"

sleep 1

 $MYSQL_BIN/mysql -h$HOST -u$USER -p$PASSWD $DB -e "alter table $t_name engine='"$D_ENGINE"'"

 if [ $? -eq 0 ] 

 then

 echo "shrink table $t_name ended." >>con_table.log

sleep 1

else 

 echo "shrink failed!" >> con_table.log

fi

done

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

连州市| 苗栗县| 安丘市| 德钦县| 汉中市| 桑日县| 克拉玛依市| 满城县| 北辰区| 扎兰屯市| 镇坪县| 蕉岭县| 龙游县| 子长县| 惠来县| 柯坪县| 怀远县| 那坡县| 平凉市| 汾阳市| 遂平县| 陆川县| 吉木乃县| 溧阳市| 慈溪市| 广州市| 巫山县| 黔江区| 安龙县| 常宁市| 商丘市| 泗水县| 太和县| 同德县| 郑州市| 敦化市| 黄骅市| 崇文区| 吴川市| 承德市| 甘洛县|