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

溫馨提示×

溫馨提示×

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

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

mysql表分區實驗總結

發布時間:2020-06-02 19:48:21 來源:網絡 閱讀:2572 作者:筆下生輝 欄目:MySQL數據庫

草稿丟失,發表得不完整,稍后重新整理


mysql表分區技術能有效解決水平拆分和垂直拆分的不足,可操作性和效率都更優。以下是一些實驗總結。


InnoDB引擎需先在配置文件中設置: innodb_file_per_table=1

--innodb : 主表.frm 保存表結構和分區數目一致的 .ibd 文件,用于保存數據和索引

--myisam:主表.frm保存表結構定義,主表.par保存分區信息,  和分區數目一致的 .MYD文件,用于保存數據,.MDI文件用于索引。

range分區:

CREATE TABLE a(   

id INT PRIMARY KEY AUTO_INCREMENT,

NAME CHAR(20))ENGINE=INNODB CHARSET=utf8

PARTITION BY RANGE(id)(

PARTITION p1 VALUES  LESS THAN (100),

PARTITION p2 VALUES  LESS THAN (200),

PARTITION p3 VALUES  LESS THAN (300),

PARTITION p4 VALUES  LESS THAN  MAXVALUE);


 ----------建立一個以id 區間來劃分的分別,當id 小于100時數據保存到p1分區,100到199時保存到p2分區,200到299時保存到p3分區,大于300時保存到p4分區; 

[root@master test]#dir

a.frm  a#P#p1.ibd  a#P#p2.ibd  a#P#p4.ibd  db.opt 





List分區:


CREATE TABLE bc(

id INT NOT NULL AUTO_INCREMENT,

par_no INT NOT NULL DEFAULT '1',

a_name CHAR(20) NOT NULL,

PRIMARY KEY(id,par_no)) ENGINE=MYISAM CHARSET=gbk PARTITION BY LIST(par_no)(

PARTITION p0 VALUES IN (10,20,30),

PARTITION p1 VALUES IN (40,50,60),

PARTITION p2 VALUES IN (70,80,100));

---插入數據時,par_no的值必須在分區定義中存在,否則不能插入并報錯。

[root@master test]# dir nb*

nb.frmnb.parnb#P#p0.MYD  nb#P#p0.MYI  nb#P#p1.MYD  nb#P#p1.MYI  nb#P#p2.MYD  nb#P#p2.MYI  nb#P#p3.MYD  nb#P#p3.MYInb#P#p4.MYD  nb#P#p4.MYI


提示警告:意思大概mysql分區以后的版本不支持myisam引擎吧,換成innodb就可以了。

Warning Code : 1287

The partition engine, used by table 'test.bc', is deprecated and will be removed in a future release. Please use native partitioning instead.

           
Hash分區:


CREATE TABLE nb(

id INT NOT NULL AUTO_INCREMENT,

par_no INT NOT NULL DEFAULT '1',

a_name CHAR(20) NOT NULL,

PRIMARY KEY(id,par_no)) ENGINE=MYISAM CHARSET=gbk PARTITION BY HASH(id)

PARTITIONS 5;           --partition 多了個s ,讓mysql自動id的Hash 值存儲到5個分區里。


查詢分區表中存在的數據量:

SELECT PARTITION_NAME,PARTITION_METHOD,PARTITION_EXPRESSION,PARTITION_DESCRIPTION,TABLE_ROWS,SUBPARTITION_NAME,SUBPARTITION_METHOD,SUBPARTITION_EXPRESSION 

FROM information_schema.PARTITIONS WHERE TABLE_SCHEMA=SCHEMA() AND TABLE_NAME='bcd'

mysql表分區實驗總結



分區管理--測試總結:

刪除分區:
ALTER TABLE tablename REMOVE PARTITIONING ; --  刪除分區定義,所有數據集中到一個表,數據不丟失
ALTER TABLE bc DROP PARTITION p1;           --刪除分區的同時會刪除分區中的數據

修改分區:
ALTER TABLE nb PARTITION BY HASH(id) PARTITIONS 2;  --Hash分區重新定義為兩個,并會重新分配數據

合并分區
ALTER TABLE  bc  REORGANIZE  PARTITION   p1,p0 INTO ( PARTITION p6 VALUES IN (10,20,30,40));  --將BC表中的p0,p1分區合并到p6分區,并且p0,p1的[list]值必須包含在新的分區內,否則不在新區[list]中的數據會丟失;

ALTER TABLE a  REORGANIZE  PARTITION p0,p1,p2 INTO (PARTITION p0 VALUES LESS THAN (500),PARTITION p1 VALUES LESS THAN maxvalue);  --重定義分區結構:將Range分區p1,p2合并到p0分區,由于原p2分區是maxvalue值,所以還得同時增加一個新的maxvalue分區,否則報錯。

拆分分區:



添加分區:

未有分區的情況下:
ALTER TABLE nb PARTITION BY HASH(id) PARTITIONS 2; --用id 列給表分兩個hash分區;如果有unique鍵,要先刪除.

ALTER TABLE a  PARTITION BY RANGE(id)(            --a 表無分區.
PARTITION p0  VALUES LESS THAN (1000),
PARTITION p1  VALUES  LESS THAN (2000),
PARTITION  p2  VALUES LESS THAN  maxvalue)
--------------------------------------------------------------------

ALTER TABLE bc  PARTITION BY LIST(par_no) (PARTITION p1             ----為未定義分區表的BC表添加兩個list分區;
VALUES IN (10,20,30),PARTITION p2 VALUES IN (40,50,60,70,80));


已有分區的情況下:
合并分區:
ALTER TABLE abc  REORGANIZE  PARTITION  p2 INTO (
PARTITION p2 VALUES LESS THAN (6000),PARTITION p3 VALUES LESS THAN maxvalue);           --重新定義Range分區p2,并新加一個p3分區,p2分區的值不能小于現有的最大值,且須新境一個包含最大值(Maxvalue)的新分區,否則報錯

ALTER TABLE bc  ADD PARTITION  (PARTITION p3 VALUES IN (20,30));--添加一個list分區

ALTER TABLE nb ADD PARTITION PARTITIONS 2;  --(Hash分區),新加后現有分區里的數據會平滑分攤到新分區,myisam引擎在上面的查詢語句中可以體現出來,innodb引擎則計數信息丟失,從0開始重新計數,但表中數據變不會丟失.

注意:刪除分區同時會將分區中的數據刪除,同時枚舉的list值也被刪除,后面無法往表中插入該值的數據。


向AI問一下細節

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

AI

卓资县| 洪洞县| 弥勒县| 宜阳县| 凤冈县| 佛冈县| 岳西县| 邢台县| 内江市| 汉寿县| 大石桥市| 城固县| 汶上县| 石景山区| 东安县| 伽师县| 延津县| 明星| 武宁县| 通江县| 灵武市| 遵化市| 泰顺县| 武城县| 孟津县| 岳阳市| 湖北省| 梧州市| 连平县| 新安县| 乌海市| 玉屏| 德格县| 龙门县| 沂水县| 浦江县| 时尚| 定日县| 霞浦县| 陕西省| 微山县|