使用 bigint 数据

整型值超过 int 数据类型支持的范围时,将使用 bigint 数据类型。为了实现兼容性,int 数据类型仍保留为 Microsoft® SQL Server™ 中的主要整型数据类型。

除非明确说明,否则,那些接受 int 表达式作为其参数的函数、语句和系统存储过程,都没有改变为支持将 bigint 表达式隐性转换为这些参数。这样,只有当 bigint 值在 int 数据类型所支持的范围内时,SQL Server 才将 bigint 隐性转换为 int。如果 bigint 表达式包含了一个在 int 数据类型支持范围之外的值,就会在运行时出现转换错误。

Transact-SQL 函数中的 bigint

虽然 SQL Server 有时会将 tinyint smallint 值提升为 int 数据类型,但是它不会自动将 tinyintsmallintint 提升为 bigint。例如,如果参数表达式的数据类型是 tinyintsmallint,某些聚合函数会把返回值的数据类型升级为 int。而这些聚合函数将不会返回 bigint,除非参数表达式本身就是 bigint 类型。

当指定 bigint 参数并且返回值也是 bigint 类型时,可以使用下列 Transact-SQL 函数。

ABS FLOOR POWER
AVG IDENTITY RADIANS
CEILING MAX ROUND
COALESCE MIN SIGN
DEGREES NULLIF SUM

当引用 bigint 列或变量,但不希望返回值也为 bigint 数据类型时,可以使用下列函数。

IDENTITY ISNULL VARP
COL_LENGTH ISNUMERIC  
DATALENGTH STDEV[P]  

SQL Server 提供下列专用于 bigint 值的函数。

COUNT_BIG

当对组中的项目计数时,如果值超过 int 数据类型支持的范围,并且返回 bigint,则使用此函数。除了返回类型外,COUNT_BIG 类似于 COUNT 函数。

ROWCOUNT_BIG

当对执行的最后一条语句所影响的行数进行计数,而且值超过 int 数据类型支持范围时,使用此函数。除了 ROWCOUNT_BIG 返回 bigint 数据类型外,此函数类似于 ROWCOUNT 函数。

其它 Transact-SQL 元素中的 bigint

CAST 和 CONVERT 子句支持 bigint。这些子句对 bigint 使用与其它整型数据类型相同的转换规则。在数据类型优先表中,bigint 数据类型位于 int 之上和 smallmoney 之下。有关 bigint 转换的更多信息,请参见 CAST 和 CONVERT

在使用 CASE 表达式时,如果 result_expression 或可选的 else_result_expression 的值是 bigint,将得到 bigint 类型的结果。

可以在 Transact-SQL 语句中指定了整型数据的所有语法位置使用 bigint 数据类型:

此外,SQL Server 目录组件报告有关 bigint 列的信息。

指定 bigint 常量

int 数据类型支持的范围之外的整数常量仍被解释为 numeric,这些数字的小数位数为 0,其精度为足以保存所指定的值。例如,常量 3000000000 被解释为 numeric。这些 numeric 常量被隐性转换为 bigint,并可对 bigint 列和变量赋值:

CREATE TABLE BigintTable (ColA bigint)

INSERT INTO BigintTable VALUES (3000000000)

SELECT *
FROM BigintTable
WHERE ColA = 3000000000

还可以将常量转换为 bigint

CAST(3000000000 AS bigint)

若要将 bigint 值放入 sql_variant 列中,请使用此方法:

CREATE TABLE VariantTable (ColA sql_variant)

-- Inserts a value with a numeric base data type.
INSERT INTO VariantTable VALUES (3000000000)
-- Inserts a value with a bigint base data type.
INSERT INTO VariantTable VALUES ( CAST(3000000000 AS bigint) )

请参见

CASE

CAST 和 CONVERT

COUNT_BIG

int、bigint、smallint 和 tinyint

数字数据

sql_variant