为任何指定的分区函数返回分区号,一组分区列值将映射到该分区号中。
Transact-SQL 语法约定
[ database_name. ] $PARTITION.partition_function_name(expression)
database_name
包含分区函数的数据库的名称。
partition_function_name
对其应用一组分区列值的任何现有分区函数的名称。
expression
其数据类型必须匹配或可隐式转换为其对应分区列数据类型的表达式。expression 也可以是当前参与 partition_function_name 的分区列的名称。
int
$PARTITION 返回从 1 到分区函数的分区数之间的 int 值。
$PARTITION 将针对任何有效值返回分区号,无论此值当前是否存在于使用分区函数的分区表或索引中。
以下示例将创建一个将表或索引划分为四个分区的分区函数 RangePF1。$PARTITION 用于确定将表示 RangePF1 的分区列的值 10 置于表的第 1 分区。
RangePF1
10
USE AdventureWorks ; GO CREATE PARTITION FUNCTION RangePF1 ( int ) AS RANGE FOR VALUES (10, 100, 1000) ; GO SELECT $PARTITION.RangePF1 (10) ; GO
以下示例将返回包含数据的表 TransactionHistory 的每个分区的行数。TransactionHistory 表使用分区函数 TransactionRangePF1,并在 TransactionDate 列上进行分区。
TransactionHistory
TransactionRangePF1
TransactionDate
USE AdventureWorks ; GO SELECT $PARTITION.TransactionRangePF1(TransactionDate) AS Partition, COUNT(*) AS [COUNT] FROM Production.TransactionHistory GROUP BY $PARTITION.TransactionRangePF1(TransactionDate) ORDER BY Partition ; GO
以下示例将返回表 TransactionHistory 第 5 分区的所有行。
5
SELECT * FROM Production.TransactionHistory WHERE $PARTITION.TransactionRangePF1(TransactionDate) = 5 ;