Next, DBA/Developer must create a partition scheme based on the previously created partition function using the CREATE PARTITION SCHEME statement. The partition scheme maps the partitions created by the partition function to filegroups. One or more filegroups can be specified in the partition scheme. The AS PARTITION clause of the CREATE PARTITION SCHEME statement identifies the partition function, and the TO clause specifies the filegroups. The complete syntax for the CREATE PARTITION SCHEME statement is:
CREATE PARTITION SCHEME
name_of_partition_scheme
AS PARTITION name_of_partition_function
[ALL]
TO ({file_group |
[PRIMARY]} [,...n] );
The partition scheme
created in this scenario would map the partitions to file groups as follows:After DBA/Developer has created the partition function and partition scheme, DBA/Developer must create the SalesHistory table as a partitioned table using a CREATE TABLE statement that includes an ON clause. The ON clause identifies the partition scheme and the column on which the table will be partitioned. The specified partitioning scheme identifies the partition function that is used. The complete syntax of the CREATE TABLE statement to create a partitioned table is as follows:
CREATE TABLE
table_name (column_def1, column_def2, ...)
ON name_of_partition_scheme
(partition_column_name);
The arguments
used in the statement syntax are as follows: table_name: Specifies the name of
the table to be created. column_defn: Specifies the details of the column(s) in
the table. partition_scheme_name: Specifies the name of the partition scheme
that identifies the partition function and the filegroups to which the
partitions of the table will be written. partition_column_name: Specifies the
name of the column in the table on which the table will be partitioned. The
column specified must match the column definition specified in the associated
partition function in terms of the data type, length, and precision. DBA/Developer
should not use the Transact-SQL that includes RANGE LEFT FOR VALUES (6999,
26999, 56999, 86999) in the CREATE PARTITION FUNCTION statement because this
will partition the SalesHistory table as follows:
No comments:
Post a Comment