亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mysql如何按照范圍區(qū)間創(chuàng)建分區(qū)表

 更新時間:2024年08月01日 14:42:27   作者:威贊  
在Mysql的范圍分區(qū)表定義中,分區(qū)范圍需要連續(xù)并且不會有覆蓋,定義范圍分區(qū)表時,使用VALUES LESS THAN操作符,這篇文章主要介紹了Mysql如何按照范圍區(qū)間創(chuàng)建分區(qū)表,需要的朋友可以參考下

定義

每一個分區(qū)僅包含在指定范圍內的數據列。這樣的分區(qū)方式就是范圍分區(qū)。在Mysql的范圍分區(qū)表定義中,分區(qū)范圍需要連續(xù)并且不會有覆蓋。定義范圍分區(qū)表時,使用VALUES LESS THAN操作符。在PARTITION BY RANGE語法中,建立分區(qū)表指定分區(qū)時,每一個分區(qū)都是按順序定義。使用時類似C語言和java中的if...elseif...表達式。

應用

本文的幾個舉例,都假設用戶為一家具有20個門店的音響公司創(chuàng)建員工記錄表。這20家門店的編號store_id是1到20.

CREATE TABLE employees (
    id INT NOT NULL,
    fname VARCHAR(30),
    lname VARCHAR(30),
    hired DATE NOT NULL DEFAULT '1970-01-01',
    separated DATE NOT NULL DEFAULT '9999-12-31',
    job_code INT NOT NULL,
    store_id INT NOT NULL
);

使用store_id列進行分區(qū)

使用store_id列,將員工表建立四個分區(qū)

CREATE TABLE employees (
    id INT NOT NULL,
    fname VARCHAR(30),
    lname VARCHAR(30),
    hired DATE NOT NULL DEFAULT '1970-01-01',
    separated DATE NOT NULL DEFAULT '9999-12-31',
    job_code INT NOT NULL,
    store_id INT NOT NULL
) partition by range (store_id) (
    partition p0 values less than (6),
    partition p1 values less than (11),
    partition p2 values less than (16),
    partition p3 values less than (21)
);

在這個新建的分區(qū)表中,門店1-5的員工數據,保存在第一個分區(qū)p0中;門店6-10的員工數據,保存在第二個分區(qū)p1中....

按照上面的分區(qū)表定義,Mysql很容易將數據(72, 'Mitchell', 'Wilson', '1998-06-25', DEFAULT, 7, 13) 插入第三個分區(qū)p2當中。但這家公司開了一家新的門店,第21個門店時,會出現什么樣的問題。在這個分區(qū)表的定義中,并未指定門店編碼超過20的處理方式,因此插入第21個門店的員工數據時,Mysql會報錯。Mysql給出來一個數值MAXVALUE來解決這個問題。MAXVALUE是Mysql中最大的一個數值,所有數字都會比MAXVALUE小。則構建該分區(qū)表的語句變成下面的形式

CREATE TABLE employees (
    id INT NOT NULL,
    fname VARCHAR(30),
    lname VARCHAR(30),
    hired DATE NOT NULL DEFAULT '1970-01-01',
    separated DATE NOT NULL DEFAULT '9999-12-31',
    job_code INT NOT NULL,
    store_id INT NOT NULL
) partition by range (store_id) (
    partition p0 values less than (6),
    partition p1 values less than (11),
    partition p2 values less than (16),
    partition p3 values less than MAXVALUE
);

現在,所有門店編號大于等于16的數據,都會插入到第四個分區(qū)p3當中。而當后續(xù)門店增加時,數據庫管理員和開發(fā)人員,可以為表建立新的分區(qū)。如為編號21-25門店添加新的分區(qū) ,為26-30的門店添加另一個分區(qū) 。

使用員工編號分區(qū)

使用員工編號分區(qū)的方式,是一種更加時髦的分區(qū)方法。在上面的例子中,數據庫管理員和開發(fā)人員可以使用字段job_code進行分區(qū)。如,兩位編碼用于保存店長的信息。三位編碼分配給辦公室和后勤人員。而為銷售經理分配四位編碼。則可以按照下面的方法來創(chuàng)建分區(qū)表

CREATE TABLE employees (
    id INT NOT NULL,
    fname VARCHAR(30),
    lname VARCHAR(30),
    hired DATE NOT NULL DEFAULT '1970-01-01',
    separated DATE NOT NULL DEFAULT '9999-12-31',
    job_code INT NOT NULL,
    store_id INT NOT NULL
) partition by range (job_code) (
    partition p0 values less than (100),
    partition p1 values less than (1000),
    partition p2 values less than (10000)
);

使用日期時間字段建立分區(qū)

除了使用門店編號,和員工代碼分區(qū)外,還可以使用時間列來建立分區(qū)表。假設現在需要使用員工的離職年份建立分區(qū)。即使用YEAR(seperated)表達式返回的值來確定分區(qū)范圍。則使用下面的語句建立分區(qū)表

CREATE TABLE employees (
    id INT NOT NULL,
    fname VARCHAR(30),
    lname VARCHAR(30),
    hired DATE NOT NULL DEFAULT '1970-01-01',
    separated DATE NOT NULL DEFAULT '9999-12-31',
    job_code INT NOT NULL,
    store_id INT NOT NULL
) partition by range (YEAR(separated)) (
    partition p0 values less than (1991),
    partition p1 values less than (1996),
    partition p2 values less than (2001),
    partition p4 values less than MAXVALUE
);

在上面的分區(qū)表中,1991年前離職的員工在分區(qū)p0中,而在1991-1995年離職的員工,在分區(qū)p1中...

當然,也可以基于TIMESTAMP字段,按照時間范圍來建立分區(qū)表,使用UNIX_TIMESTAMP()方法,建立分區(qū)表如下。

CREATE TABLE quarterly_report_status (
  report_id INT NOT NULL,
  report_status VARCHAR(20) NOT NULL,
  report_updated TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
)
PARTITION BY RANGE ( UNIX_TIMESTAMP(report_updated) ) (
  PARTITION p0 VALUES LESS THAN ( UNIX_TIMESTAMP('2008-01-01 00:00:00') ),
  PARTITION p1 VALUES LESS THAN ( UNIX_TIMESTAMP('2008-04-01 00:00:00') ),
  PARTITION p2 VALUES LESS THAN ( UNIX_TIMESTAMP('2008-07-01 00:00:00') ),
  PARTITION p3 VALUES LESS THAN ( UNIX_TIMESTAMP('2008-10-01 00:00:00') ),
  PARTITION p4 VALUES LESS THAN ( UNIX_TIMESTAMP('2009-01-01 00:00:00') ),
  PARTITION p5 VALUES LESS THAN ( UNIX_TIMESTAMP('2009-04-01 00:00:00') ),
  PARTITION p6 VALUES LESS THAN ( UNIX_TIMESTAMP('2009-07-01 00:00:00') ),
  PARTITION p7 VALUES LESS THAN ( UNIX_TIMESTAMP('2009-10-01 00:00:00') ),
  PARTITION p8 VALUES LESS THAN ( UNIX_TIMESTAMP('2010-01-01 00:00:00') ),
  PARTITION p9 VALUES LESS THAN (MAXVALUE)
);

使用時間段分區(qū)使用下面的場景

  • 當開發(fā)人員或數據庫管理員想要刪除舊數據的時候,如前面的employee表,用戶可以簡單的使用ALTER TABLE employees DROP PARTITION p0,來刪除1991年前離職員工的所有數據。當有很多數據需要刪除時,使用這種刪除方法比使用DELETE方法刪除數據效率會高很多。
  • 用戶想要使用時間或其他序列的字段來操作數據表
  • 用戶經常使用表分區(qū)字段來進行查詢。如當執(zhí)行下面這條語句.Mysql能夠快速的使用where查詢條件找到第三個分區(qū)p2, 而不需要掃描其他分區(qū)的數據。
EXPLAIN SELECT COUNT(*) FROM employees WHERE seperated BETWEEN '2000-01-01' AND '2000-12-31' GROUP BY store_id

范圍分區(qū)列

與范圍分區(qū)相似的用法就是分區(qū)列。使用RANGE COLUMNS方法構建分區(qū)表,允許用戶使用多個列來建立分區(qū)表。這些列可以共同用于查詢時對掃描數據的修剪和過濾。

使用范圍分區(qū)列來創(chuàng)建分區(qū)表。

CREATE TABLE members (
    firstname VARCHAR(25) NOT NULL,
    lastname VARCHAR(25) NOT NULL,
    username VARCHAR(16) NOT NULL,
    email VARCHAR(35),
    joined DATE NOT NULL
)
PARTITION BY RANGE COLUMNS(joined) (
    PARTITION p0 VALUES LESS THAN ('1960-01-01'),
    PARTITION p1 VALUES LESS THAN ('1970-01-01'),
    PARTITION p2 VALUES LESS THAN ('1980-01-01'),
    PARTITION p3 VALUES LESS THAN ('1990-01-01'),
    PARTITION p4 VALUES LESS THAN MAXVALUE
);

到此這篇關于Mysql按照范圍區(qū)間創(chuàng)建分區(qū)表的文章就介紹到這了,更多相關Mysql創(chuàng)建分區(qū)表內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 解讀mysql的for update用法

    解讀mysql的for update用法

    這篇文章主要介紹了解讀mysql的for update用法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 解讀mysql刪除操作和查詢操作哪個更消耗性能

    解讀mysql刪除操作和查詢操作哪個更消耗性能

    文章討論了MySQL中刪除操作比查詢操作更消耗性能的原因,包括表級鎖定、磁盤空間浪費、索引稀疏化和事務日志膨脹,同時,文章還提出了一些減少刪除操作對性能影響的策略,如確保表上有合適的索引、分批次刪除和使用合適的WHERE條件
    2025-02-02
  • 關于Mysql update修改多個字段and的語法問題詳析

    關于Mysql update修改多個字段and的語法問題詳析

    這篇文章主要給大家介紹了關于mysql update修改多個字段and的語法問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • MySQL 5.6 GTID新特性實踐

    MySQL 5.6 GTID新特性實踐

    GTID(Global Transaction ID)是對于一個已提交事務的編號,并且是一個全局唯一的編號。下文給大家介紹MySQL 5.6 GTID新特性實踐,感興趣的朋友一起看看吧
    2016-10-10
  • mysql視圖之創(chuàng)建視圖(CREATE VIEW)和使用限制實例詳解

    mysql視圖之創(chuàng)建視圖(CREATE VIEW)和使用限制實例詳解

    這篇文章主要介紹了mysql視圖之創(chuàng)建視圖(CREATE VIEW)和使用限制,結合實例形式詳細分析了mysql視圖創(chuàng)建于使用相關原理與操作注意事項,需要的朋友可以參考下
    2019-12-12
  • 從MySQL 5.5遷移到Mariadb 10.1.14所遇到的問題

    從MySQL 5.5遷移到Mariadb 10.1.14所遇到的問題

    這篇文章主要介紹了從MySQL 5.5遷移到Mariadb 10.1.14所遇到的問題的相關資料,需要的朋友可以參考下
    2016-08-08
  • 如何解決mysql表輸入中文出現問號的問題

    如何解決mysql表輸入中文出現問號的問題

    這篇文章主要介紹了如何解決mysql表輸入中文出現問號的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 在MySQL中實現基于時間點的數據恢復

    在MySQL中實現基于時間點的數據恢復

    在MySQL中實現基于時間點的數據恢復是一個復雜但可行的過程,主要依賴于MySQL的二進制日志(Binary Log),本文介紹了實現此功能的一般步驟,并有詳細的代碼供大家參考,需要的朋友可以參考下
    2024-03-03
  • MySql?查詢符合條件的最新數據行

    MySql?查詢符合條件的最新數據行

    這篇文章主要介紹了MySql?怎么查出符合條件的最新的數據行,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • mysql8.0主從復制搭建與配置方案

    mysql8.0主從復制搭建與配置方案

    MySQL主從復制是一個異步的復制過程,就是有兩個數據庫服務器,一個是主(master)數據庫服務器,另一個是從(slave)數據庫服務器。
    2022-09-09

最新評論