1. 程式人生 > >mysql表分割槽簡述

mysql表分割槽簡述

一、 簡介

資料庫分割槽

資料庫分割槽是一種物理資料庫設計技術。雖然分割槽技術可以實現很多效果,但其主要目的是為了在特定的SQL操作中減少資料讀寫的總量以縮減sql語句的響應時間,同時對於應用來說分割槽完全是透明的。

MYSQL的分割槽主要有兩種形式:水平分割槽和垂直分割槽

水平分割槽(HorizontalPartitioning)

這種形式的分割槽是對根據表的行進行分割槽,通過這樣的方式不同分組裡面的物理列分割的資料集得以組合,從而進行個體分割(單分割槽)或集體分割(1個或多個分割槽)。
所有在表中定義的列在每個資料集中都能找到,所以表的特性依然得以保持。水平分割槽一定要通過某個屬性列來分割。常見的比如年份,日期等。

垂直分割槽(VerticalPartitioning)

這種分割槽方式一般來說是通過對錶的垂直劃分來減少目標表的寬度,使某些特定的列被劃分到特定的分割槽,每個分割槽都包含了其中的列所對應所有行。
可以用  showvariables like '%partition%';

命令查詢當前的mysql資料庫版本是否支援分割槽。

分割槽的作用:資料庫效能的提升和簡化資料管理

在掃描操作中,mysql優化器只掃描保護資料的那個分割槽以減少掃描範圍獲得性能的提高。

分割槽技術使得資料管理變得簡單,刪除某個分割槽不會對另外的分割槽造成影響,分割槽有系統直接管理不用手工干預。

mysql從5.1版本開始支援分割槽。每個分割槽的名稱是不區分大小寫。同個表中的分割槽表名稱要唯一。

二、       mysql分割槽型別

根據所使用的不同分割槽規則可以分成幾大分割槽型別。

RANGE 分割槽:

基於屬於一個給定連續區間的列值,把多行分配給分割槽。

LIST 分割槽:

類似於按RANGE分割槽,區別在於LIST分割槽是基於列值匹配一個離散值集合中的某個值來進行選擇。

HASH分割槽:

基於使用者定義的表示式的返回值來進行選擇的分割槽,該表示式使用將要插入到表中的這些行的列值進行計算。這個函式可以包含MySQL中有效的、產生非負整數值的任何表示式。

KEY
分割槽:類似於按HASH分割槽,區別在於KEY分割槽只支援計算一列或多列,且MySQL伺服器提供其自身的雜湊函式。必須有一列或多列包含整數值。

複合分割槽:

基於RANGE/LIST 型別的分割槽表中每個分割槽的再次分割。子分割槽可以是 HASH/KEY 等型別。

三、       mysql分割槽表常用操作示例

以部門員工表為例子:

1)       建立range分割槽

create table emp

(empno varchar(20) not null ,

empname varchar(20),

deptno int,

birthdate date,

salary int

)

partition by range(salary)

(

partition p1 values less than (1000),

partition p2 values less than (2000),

partition p3 values less than maxvalue

);

以員工工資為依據做範圍分割槽。

create table emp

(empno varchar(20) not null ,

empname varchar(20),

deptno int,

birthdate date not null,

salary int

)

partition by range(year(birthdate))

(

partition p1 values less than (1980),

partition p2 values less than (1990),

partition p3 values less than maxvalue

);

year(birthdate)表示式(計算員工的出生日期)作為範圍分割槽依據。這裡最值得注意的是表示式必須有返回值。

2)       建立list分割槽

create table emp

(empno  varchar(20) not null ,

empname varchar(20),

deptno  int,

birthdate date not null,

salary int

)

partition by list(deptno)

(

partition p1 values in  (10),

partition p2 values in  (20),

partition p3 values  in  (30)

);

以部門作為分割槽依據,每個部門做一分割槽。

3)       建立hash分割槽

HASH分割槽主要用來確保資料在預先確定數目的分割槽中平均分佈。在RANGE和LIST分割槽中,必須明確指定一個給定的列值或列值集合應該儲存在哪 個分割槽中;而在HASH分割槽中,MySQL 自動完成這些工作,你所要做的只是基於將要被雜湊的列值指定一個列值或表示式,以及指定被分割槽的表將要被分割成的分割槽數量。

create table emp

(empno varchar(20) not null ,

empname varchar(20),

deptno int,

birthdate date not null,

salary int

)

partition by hash(year(birthdate))

partitions 4;

4)       建立key分割槽

按照KEY進行分割槽類似於按照HASH分割槽,除了HASH分割槽使用的使用者定義的表示式,而KEY分割槽的雜湊函式是由MySQL 伺服器提供,伺服器使用其自己內部的雜湊函式,這些函式是基於與PASSWORD()一樣的運演算法則。“CREATE TABLE ...PARTITION BY KEY”的語法規則類似於建立一個通過HASH分割槽的表的規則。它們唯一的區別在於使用的關鍵字是KEY而不是HASH,並且KEY分割槽只採用一個或多個 列名的一個列表。

create table emp

(empno varchar(20) not null ,

empname varchar(20),

deptno int,

birthdate date not null,

salary int

)

partition by key(birthdate)

partitions 4;

5)       建立複合分割槽

range - hash(範圍雜湊)複合分割槽

create table emp

(empno varchar(20) not null ,

empname varchar(20),

deptno int,

birthdate date not null,

salary int

)

partition by range(salary)

subpartition by hash(year(birthdate))

subpartitions 3

(

partition p1 values less than (2000),

partition p2 values less than maxvalue

);

range- key複合分割槽

create table emp

(empno varchar(20) not null ,

empname varchar(20),

deptno int,

birthdate date not null,

salary int

)

partition by range(salary)

subpartition by key(birthdate)

subpartitions 3

(

partition p1 values less than (2000),

partition p2 values less than maxvalue

);

list - hash複合分割槽

CREATE TABLE emp (

empno varchar(20) NOT NULL,

empname varchar(20) ,

deptno int,

birthdate date NOT NULL,

salary int

)

PARTITION BY list (deptno)

subpartition by hash(year(birthdate))

subpartitions 3

(

PARTITION p1 VALUES in  (10),

PARTITION p2 VALUES in  (20)

)

;

list - key 複合分割槽

CREATE TABLE empk (

empno varchar(20) NOT NULL,

empname varchar(20) ,

deptno int,

birthdate date NOT NULL,

salary int

)

PARTITION BY list (deptno)

subpartition by key(birthdate)

subpartitions 3

(

PARTITION p1 VALUES in  (10),

PARTITION p2 VALUES in  (20)

)

;

6)       分割槽表的管理操作

刪除分割槽:

alter table emp drop partition p1;

不可以刪除hash或者key分割槽。

一次性刪除多個分割槽,alter table emp drop partition p1,p2;

增加分割槽:

alter table emp add partition (partition p3 values less than (4000));

alter table empl add partition (partition p3 values in (40));

分解分割槽:

Reorganizepartition關鍵字可以對錶的部分分割槽或全部分割槽進行修改,並且不會丟失資料。分解前後分割槽的整體範圍應該一致。

alter table te

reorganize partition p1 into

(

partition p1 values less than (100),

partition p3 values less than (1000)

); ----不會丟失資料

合併分割槽:

Merge分割槽:把2個分割槽合併為一個。
alter table te

reorganize partition p1,p3 into

(partition p1 values less than (1000));

----不會丟失資料

重新定義hash分割槽表:

Alter table emp partition by hash(salary)partitions 7;

----不會丟失資料

重新定義range分割槽表:

Alter table emp partitionbyrange(salary)

(

partition p1 values less than (2000),

partition p2 values less than (4000)

); ----不會丟失資料

刪除表的所有分割槽:

Alter table emp removepartitioning;--不會丟失資料

重建分割槽:

這和先刪除儲存在分割槽中的所有記錄,然後重新插入它們,具有同樣的效果。它可用於整理分割槽碎片。

ALTER TABLE emp rebuild partitionp1,p2;

優化分割槽:

如果從分割槽中刪除了大量的行,或者對一個帶有可變長度的行(也就是說,有VARCHAR,BLOB,或TEXT型別的列)作了許多修改,可以使用“ALTER TABLE ... OPTIMIZE PARTITION”來收回沒有使用的空間,並整理分割槽資料檔案的碎片。

ALTER TABLE emp optimize partition p1,p2;

分析分割槽:

讀取並儲存分割槽的鍵分佈。

ALTER TABLE emp analyze partition p1,p2;

修補分割槽:

修補被破壞的分割槽。

ALTER TABLE emp repairpartition p1,p2;

檢查分割槽:

可以使用幾乎與對非分割槽表使用CHECK TABLE 相同的方式檢查分割槽。

ALTER TABLE emp CHECK partition p1,p2;

這個命令可以告訴你表emp的分割槽p1,p2中的資料或索引是否已經被破壞。如果發生了這種情況,使用“ALTER TABLE ... REPAIR PARTITION”來修補該分割槽。

【mysql分割槽表的侷限性】

1.      在5.1版本中分割槽表對唯一約束有明確的規定,每一個唯一約束必須包含在分割槽表的分割槽鍵(也包括主鍵約束)。

CREATE TABLE emptt (

empno varchar(20) NOT NULL  ,

empname varchar(20),

deptno int,

birthdate date NOT NULL,

salary int ,

primary key (empno)

)

PARTITION BY range (salary)

(

PARTITION p1 VALUES less than (100),

PARTITION p2 VALUES less than (200)

);

這樣的語句會報錯。MySQL Database Error: A PRIMARY KEY must include allcolumns in the table's partitioning function;

CREATE TABLE emptt (

empno varchar(20) NOT NULL  ,

empname varchar(20) ,

deptno int(11),

birthdate date NOT NULL,

salary int(11) ,

primary key (empno,salary)

)

PARTITION BY range (salary)

(

PARTITION p1 VALUES less than (100),

PARTITION p2 VALUES less than (200)

);

在主鍵中加入salary列就正常。

2.      MySQL分割槽處理NULL值的方式

如果分割槽鍵所在列沒有notnull約束。

如果是range分割槽表,那麼null行將被儲存在範圍最小的分割槽。

如果是list分割槽表,那麼null行將被儲存到list為0的分割槽。

在按HASH和KEY分割槽的情況下,任何產生NULL值的表示式mysql都視同它的返回值為0。

為了避免這種情況的產生,建議分割槽鍵設定成NOT NULL。

3.      分割槽鍵必須是INT型別,或者通過表示式返回INT型別,可以為NULL。唯一的例外是當分

區型別為KEY分割槽的時候,可以使用其他型別的列作為分割槽鍵( BLOB or TEXT 列除外)。

4.      對分割槽表的分割槽鍵建立索引,那麼這個索引也將被分割槽,分割槽鍵沒有全域性索引一說。

5.      只有RANG和LIST分割槽能進行子分割槽,HASH和KEY分割槽不能進行子分割槽。

6.      臨時表不能被分割槽。

四、       獲取mysql分割槽表資訊的幾種方法

1.     show create table 表名
可以檢視建立分割槽表的create語句

2.     show table status
可以查看錶是不是分割槽表

3.     檢視information_schema.partitions表
select
  partition_name part, 
  partition_expression expr, 
  partition_description descr, 
  table_rows 
from information_schema.partitions  where
  table_schema = schema() 
  and table_name='test'; 
可以查看錶具有哪幾個分割槽、分割槽的方法、分割槽中資料的記錄數等資訊

4.     explain partitions select語句
通過此語句來顯示掃描哪些分割槽,及他們是如何使用的.

五、       分割槽表效能比較

1.     建立兩張表: part_tab(分割槽表),no_part_tab(普通表)

CREATE TABLEpart_tab

( c1 int defaultNULL, c2 varchar2(30) default NULL, c3 date not null)

PARTITION BYRANGE(year(c3))

(PARTITION p0VALUES LESS THAN (1995),

PARTITION p1 VALUESLESS THAN (1996) ,

PARTITION p2 VALUESLESS THAN (1997) ,

PARTITION p3 VALUESLESS THAN (1998) ,

 PARTITION p4 VALUES LESS THAN (1999) ,

PARTITION p5 VALUESLESS THAN (2000) ,

PARTITION p6 VALUESLESS THAN (2001) ,

PARTITION p7 VALUESLESS THAN (2002) ,

PARTITION p8 VALUESLESS THAN (2003) ,

PARTITION p9 VALUESLESS THAN (2004) ,

PARTITION p10VALUES LESS THAN (2010),

PARTITION p11VALUES LESS THAN (MAXVALUE) );

CREATE TABLE no_part_tab

( c1 int defaultNULL, c2 varchar2(30) default NULL, c3 date not null);

2.     用儲存過程插入800萬條資料

CREATE PROCEDUREload_part_tab()

    begin

    declare v int default 0;

    while v < 8000000

    do

        insert into part_tab

        values (v,'testingpartitions',adddate('1995-01-01',(rand(v)*36520)mod 3652));

         set v = v + 1;

    end while;

end;

insert into no_part_tab  select * frompart_tab;

3.     測試sql效能

查詢分割槽表:

selectcount(*) from part_tab where c3 > date '1995-01-01'and c3 < date '1995-12-31';

+----------+
| count(*) |
+----------+
|   795181 |
+----------+
1 row in set (2.62 sec)

查詢普通表:

selectcount(*) from part_tab where c3 > date '1995-01-01'and c3 < date '1995-12-31';

+----------+
| count(*) |
+----------+
|   795181 |
+----------+
1 row in set (7.33 sec)

分割槽表的執行時間比普通表少70%。

4.     通過explain語句來分析執行情況

mysql>explain select count(*) from part_tab where c3 > date '1995-01-01'and c3 < date '1995-12-31';

+----+-------------+----------+------+---------------+------+---------+------+---------+-------------+

| id |select_type | table    | type |possible_keys | key  | key_len | ref  | rows   | Extra       |

+----+-------------+----------+------+---------------+------+---------+------+---------+-------------+

|  1 | SIMPLE      | part_tab | ALL  | NULL          | NULL | NULL    | NULL | 7980796 | Using where |

+----+-------------+----------+------+---------------+------+---------+------+---------+-------------+

1 rowin set

mysql>explain select count(*) from no_part_tab where c3 > date '1995-01-01'and c3 < date '1995-12-31';

+----+-------------+-------------+------+---------------+------+---------+------+---------+-------------+

| id |select_type | table       | type |possible_keys | key  | key_len | ref  | rows   | Extra       |

+----+-------------+-------------+------+---------------+------+---------+------+---------+-------------+

|  1 | SIMPLE      | no_part_tab | ALL  | NULL          | NULL | NULL    | NULL | 8000206 | Using where |

+----+-------------+-------------+------+---------------+------+---------+------+---------+-------------+

1 rowin set

mysql >

分割槽表執行掃描了7980796行,而普通表則掃描了8000206行。

相關推薦

mysql分割槽簡述

一、 簡介 資料庫分割槽 資料庫分割槽是一種物理資料庫設計技術。雖然分割槽技術可以實現很多效果,但其主要目的是為了在特定的SQL操作中減少資料讀寫的總量以縮減sql語句的響應時間,同時對於應用來說分割槽完全是透明的。 MYSQL的分割槽主要有兩種形式:水平分割槽和垂直分割槽 水平分割槽(Horizonta

MysqlMysql分割槽型別及示例

前言 檢視分割槽: SELECT PARTITION_NAME, PARTITION_METHOD, PARTITION_EXPRESSION, PARTITION_DESCRIPTION, TABLE_ROWS, SUBPARTITION_NAME, SUBPARTITION

檢視Mysql分割槽語句

SELECT partition_name part, partition_expression expr, partition_description descr, table_rows FROM INFORMATION_SCHEMA.partitions W

mysql分割槽語句記錄

建立分割槽表 CREATE TABLE realtable ( id int(10)unsigned NOT NULL COMMENT'表主鍵', pid int(10)unsigned NOT NULL COMMENT'產品ID', price decimal(1

MYSQL分割槽,檢視分割槽

一、       mysql分割槽簡介 資料庫分割槽 資料庫分割槽是一種物理資料庫設計技術。雖然分割槽技術可以實現很多效果,但其主要目的是為了在特定的SQL操作中減少資料讀寫的總量以縮減sql語句的響應時間,同時對於應用來說分割槽完全是透明的。 MYSQL的分割槽主要有

Mysqlmysql分割槽2 —Range分割槽

按照RANGE分割槽的表是通過如下一種方式進行分割槽的,每個分割槽包含那些分割槽表示式的值位於一個給定的連續區間內的行。這些區間要連續且不能相互重疊,使用VALUES LESS THAN操作符來進行定義。在下面的幾個例子中,假定你建立了一個如下的一個表,該表儲存有20家

建立mysql分割槽的方法

表分割槽是最近才知道的哦 ,以前自己做都是分表來實現上億級別的資料了,下面我來給大家介紹一下mysql表分割槽建立與使用吧,希望對各位同學會有所幫助。 表分割槽的測試使用,主要內容來自於其他部落格文章以及mysql5.1的參考手冊 mysql測試版本:mysql5.5.28 mysql物理儲存檔案(有mysq

mysql 分割槽 按天分割槽

 MySQL表分割槽就是把一張表根據設定好的條件下把表切分成若干個小表相互之間,在MySQL的5.1版本以後就開始支援表分割槽的功能,在使用表的分割槽後會使MySQL中大表在平時查詢統計時效能提升。使用MySQL的表分割槽有以下這些優點: 1.與單個磁碟或檔案系統分

mysql分割槽例子

1.表結構: CREATE TABLE `students` ( `stu_id` int(11) NOT NULL AUTO_INCREMENT, `stu_name` int(11) DEFAULT NULL, `stu_sex` int(11) DEFAU

MySQL分割槽(3)雜湊分割槽-hash

  雜湊分割槽。雜湊分割槽主要是依據表的某個欄位以及指定分割槽的數量。 建立表分割槽    要使用HASH分割槽來分割一個表,要在CREATE TABLE 語句上新增一個“PARTITION BY HASH (expr)”子句,其中“expr”是一個返回一個整數的表示式。它

Mysql給現有分割槽遇到的問題

一、需要注意的問題: 1、分割槽的欄位必須是主鍵 2、不可以建立兩個主鍵,只能建立複合主鍵,所以要將原來的主鍵刪除再建立新的複合主鍵 3、要刪除原來的主鍵必須要先刪除對應欄位上的自增 二、操作步驟 1、刪除自增: alter table shop modify shop_id

012-- mysql分割槽和分

分割槽 分割槽就是把一個數據表的檔案和索引分散儲存在不同的物理檔案中。 mysql支援的分割槽型別包括Range、List、Hash、Key,其中Range比較常用: RANGE分割槽:基於屬於一個給定連續區間的列值,把多行分配給分割槽。 LIST分割槽:類似於按RANGE分

mysql分割槽和分

分割槽 分割槽就是把一個數據表的檔案和索引分散儲存在不同的物理檔案中。 mysql支援的分割槽型別包括Range、List、Hash、Key,其中Range比較常用: RANGE分割槽:基於屬於一個給定連續區間的列值,把多行分配給分割槽。 LIST分割槽:類似於按

5.【MYSQL分割槽&分庫&分

Mysql分割槽分庫分表 1.mysql分割槽 1.1Range分割槽 1.2List分割槽 1.3Hash分割槽 1.4 2.水平分割 3.垂直分割 1.m

MySql資料庫分分割槽實踐

1. 背景 —— 公司物聯網專案 海量裝置通過物聯網服務接入雲端,裝置每30s上報一次自身資料(以下稱為動態資料)。 物聯網服務將裝置上報的資料轉發給資料處理閘道器,由資料入庫閘道器執行批量入庫操作插入資料庫。 專案大致技術架構如下圖: 2. 問題 接入的裝置數量較大時,上報的動態資料

MYSQL分割槽----按日期分割槽

錯誤的按日期分割槽例子 最直觀的方法,就是直接用年月日這種日期格式來進行常規的分割槽: PLAIN TEXT CODE:mysql> create table rms (d date) -> partition by range (d) -&

MySQL分割槽詳解

一、什麼是表分割槽 通俗地講表分割槽是將一大表,根據條件分割成若干個小表。mysql5.1開始支援資料表分割槽了。 如:某使用者表的記錄超過了600萬條,那麼就可以根據入庫日期將表分割槽,也可以根據所在地將表分割槽。當然也可根據其他的條件分割槽。二、為什麼要對錶進行分割槽 為了改善大型表以及具有各種訪問

Mysql分割槽

因hive資料在20180101 用sqoop同步到mysql的時候出錯,最終查詢原因發現是因為mysql中 對應的表的分割槽沒有建導致的,順帶研究下mysql的分割槽表 mysql的分割槽表的概述 mysql中分割槽表的定義: 將一個表

MySQL的四種分割槽型別

一、什麼是表分割槽 通俗地講表分割槽是將一大表,根據條件分割成若干個小表。mysql5.1開始支援資料表分割槽了。 如:某使用者表的記錄超過了600萬條,那麼就可以根據入庫日期將表分割槽,也可以根據所在地將表分割槽。當然也可根據其他的條件分割槽。 二、為什麼要對錶進行分割槽 為了改善大型表以

【轉】mysql分割槽和分

地址:https://www.cnblogs.com/phpshen/p/6198375.html 分割槽 分割槽就是把一個數據表的檔案和索引分散儲存在不同的物理檔案中。 mysql支援的分割槽型別包括Range、List、Hash、Key,其中Range比較常用: