mysql 表分区创建sql_MSSQL表分区的创建详细讲解过程

现在基本所有数据库都存在表分区的概念,但MSSQL表分区一些细节又不一样,我现在也是有一定的了解,因此本篇文章不做很细的原理性质的讲解,主要讲一下MSSQL表分区的创建过程。

首先创建新的文件,分别放到我本机的D:SPPartition文件夹下的FirstPart,SecondPart,ThirdPart文件夹,新建3个文件文件分别对应3个文件组,以我本机中存在的数据库CenterMy为例子,它现在有个表TestSP,这是一个用户表,现在测试数据只有1000多条数据,创建代码如下:

代码如下

复制代码

ALTER DATABASE CenterMy

ADD FILEGROUP FGSP1

GO

ALTER DATABASE CenterMy

ADD FILE

(

NAME = 'SPTestLevel1',

FILENAME = 'D:SPPartitionFirstPartSPTestLevel1.ndf',

SIZE = 5120 KB,

MAXSIZE = UNLIMITED,

FILEGROWTH = 5120 KB

) TO FILEGROUP FGSP1

GO创建文件组FSSP1,默认起始大小5M,最大文件数据不限制,根据实际数量大小文件以5M递增,下面创建的文件一样以这样的配置创建,文件组添加对应一个数据库文件SPTestLevel1.ndf。

代码如下

复制代码

ALTER DATABASE CenterMy

ADD FILEGROUP FGSP2

GO

ALTER DATABASE CenterMy

ADD FILE

(

NAME = 'SPTestLevel2',

FILENAME = 'D:SPPartitionSecondPartSPTestLevel2.ndf',

SIZE = 5120 KB,

MAXSIZE = UNLIMITED,

FILEGROWTH = 5120 KB

) TO FILEGROUP FGSP2

GO创建文件组FSSP2,添加对应一个数据库文件SPTestLevel2.ndf。

代码如下

复制代码

ALTER DATABASE CenterMy

ADD FILEGROUP FGSP3

GO

ALTER DATABASE CenterMy

ADD FILE

(

NAME = 'SPTestLevel3',

FILENAME = 'D:SPPartitionThirdPartSPTestLevel3.ndf',

SIZE = 5120 KB,

MAXSIZE = UNLIMITED,

FILEGROWTH = 5120 KB

) TO FILEGROUP FGSP3

GO创建文件组FSSP3,添加对应一个数据库文件SPTestLevel3.ndf。

查询当前数据库CenterMy的分组:

代码如下

复制代码

SELECT *

FROM sys.filegrou可以看到已经有4个分组了,因为默认有PRIMARY主文件组。

查看当前数据文件:

代码如下

复制代码

SELECT *

FROM sys.database_files可以分别看到数据文件所在目录。

下面创建分区函数,它将为分区中数据分布制定标准。

代码如下

复制代码

CREATE PARTITION FUNCTION TestSPFunction (INT)

AS RANGE RIGHT FOR VALUES ( 500, 1000,1300)

GO这里Range定义的范围可以是RIGHT或LEFT,我们这里使用的范围是RIGHT,RIGHT表明是=,LEFT表明是<=或>。即<500是一个区,>=500并且<1000是一个区,>=1000并且<1300是一个取,>=1300是一个分区,这里相当于分了4个段的分区。

然后创建分区方案,它将创建的分区函数映射到文件组,文件组对应磁盘上的物理数据库文件。

代码如下

复制代码

CREATE PARTITION SCHEME TestSPScheme

AS PARTITION TestSPFunction

TO ([PRIMARY], FGSP1, FGSP2,FGSP3 )

GO这里把分区函数的4个段对应到4个文件组上。

然后把表链接到分区方案,这里使用SPNO主键作为分区列。

ALTER TABLE TestSP add CONSTRAINT [PK_SPNO] PRIMARY KEY CLUSTERED (SPNo)

ON TestSPScheme(SPNo)

通过上面的操作,表分区就创建好了,并且数据自动放到相应的分区中了,下面我们查询下各个分区对应的数据量。

*

FROM sys.partitions

WHERE OBJECT_NAME(OBJECT_ID)='TestSP'

可以看到主分区有467条记录,partion_number的1,2,3,4分别对应不同文件组对应的row数据条数。

13B601UB5C0-B263.jpg

最后查询表的时候,可以在完全不知道表分区的情况下查询,我们查看下数据对应的所在分区:

SELECT *, $PARTITION.TestSPFunction(SPNo)

FROM TestSP

13B601UH4620-L9D.jpg

发现SPNO为500的正好在第二个分区了,证明我们创建表分区成功了!

上面只是简单描述了下表分区的过程,MSSQL2008还新增了可视化界面来添加表分区,如图:

13B601UL6260-Y248.jpg

本文主要是展现了分区的过程,对于实际项目中,是否需要分区,怎么分区,分区部署到什么磁盘上,分区后索引创建以及是否能达到优化的效果,还需要再根据实际情况更多的考虑,

f68f2add0b68e4f9810432fce46917b7.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您解答这个问题。 MySQL分区表可以提高查询性能,并且可以通过按时间范围进行自动分区,以便更好地管理和维护数据。下面是按天执行分区表SQL的步骤: 1. 创建分区表 您可以使用以下命令创建一个按天分区: ``` CREATE TABLE mytable ( id INT NOT NULL, created_at TIMESTAMP NOT NULL ) PARTITION BY RANGE(TO_DAYS(created_at)) ( PARTITION p0 VALUES LESS THAN (TO_DAYS('2022-01-01')), PARTITION p1 VALUES LESS THAN (TO_DAYS('2022-01-02')), PARTITION p2 VALUES LESS THAN (TO_DAYS('2022-01-03')), ... PARTITION pn VALUES LESS THAN MAXVALUE ); ``` 这将创建一个名为“mytable”的分区表,其中“created_at”列将用于分区分区将按天进行。您需要为每个分区指定值范围,例如“p0”分区包含所有在“2022-01-01”之前创建的记录。 2. 创建分区维护事件 您可以创建一个事件,定期检查创建新的分区。以下是一个示例事件: ``` CREATE EVENT partition_maintenance ON SCHEDULE EVERY 1 DAY DO ALTER TABLE mytable ADD PARTITION ( PARTITION pmax VALUES LESS THAN MAXVALUE ); ``` 这将创建一个名为“partition_maintenance”的事件,每天运行一次,它将在“mytable”创建一个新的分区。 3. 自动分区 您可以在中插入数据时自动创建分区。以下是一个示例触发器: ``` CREATE TRIGGER partition_insert BEFORE INSERT ON mytable FOR EACH ROW BEGIN DECLARE partition_name VARCHAR(20); SET partition_name = CONCAT('p', DATE_FORMAT(NEW.created_at, '%Y%m%d')); SET @partition_sql = CONCAT('PARTITION ', partition_name, ' VALUES LESS THAN (TO_DAYS(\'', DATE_ADD(DATE(NEW.created_at), INTERVAL 1 DAY), '\'))'); SET @sql = CONCAT('ALTER TABLE mytable ADD ', @partition_sql); PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt; END; ``` 这将创建一个名为“partition_insert”的触发器,在插入新记录时自动创建新的分区。该触发器将使用新记录的“created_at”值计算分区名称,并为该名称创建一个新的分区。 总之,以上是按天执行分区表SQL的步骤,希望对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值