0

当我在兼容级别为 130 的 SQL Server 2016 数据库上运行此 T-SQL 时,出现错误:

DECLARE @myVariable int = 4;

EXEC sys.sp_addextendedproperty
    @name = N'MyExtendedProperty',
    @value = FORMAT( @myVariable, 'd', 'en-US' ), 
    @level0type = N'SCHEMA', @level0name=N'dbo',
    @level1type = N'TABLE' , @level1name=N'MyTable';

错误信息如下,SSMS@myVariableFORMAT函数调用中突出了使用:

消息 102,级别 15,状态 1,第 5 行
“@myVariable”附近的语法不正确

但是,如果我使用中间变量,SQL 会成功运行:

DECLARE @myVariable int = 4;

DECLARE @myVariableText nvarchar(10) = FORMAT( @myVariable, 'd', 'en-US' )

EXEC sys.sp_addextendedproperty
    @name = N'MyExtendedProperty',
    @value = @myVariableText, 
    @level0type = N'SCHEMA', @level0name=N'dbo',
    @level1type = N'TABLE' , @level1name=N'MyTable';

我确实想知道是否FORMAT或者sp_addextendedproperty是一个神奇的函数,比如RAISERROR它需要第一个参数是字符串文字(不允许使用表达式),但是文档sp_addextendedproperty没有提到对@value参数的任何限制:

https://docs.microsoft.com/en-us/sql/relational-databases/system-stored-procedures/sp-addextendedproperty-transact-sql?view=sql-server-2017

[ @value= ] { 'value'}

是要与属性关联的值。值为sql_variant,默认值为 NULL。value 的大小不能超过 7,500 字节。

4

1 回答 1

2

将值传递给存储过程时,只能传递值,而存储过程不允许计算表达式。

exec myProc 2    is ok

exec myProc @SomeIntValue    is ok

但,

exec myProc 2 + 2   is NOT ok.

所以虽然一个简单的集合,比如

DECLARE @i as int

Set @i = (2 + 2)

exec myProc @i

以上没问题,因为您只能将“值”传递给存储过程。您不能传递表达式。实际上,对于传递给存储过程的参数,没有可用的求值或表达式服务。

所以这个问题不仅限于使用 sys.sp_addextendedproperty,也不是某种特殊情况。您面临的问题适用于存储过程的任何类型的调用和使用。

因此,在集合中,或者说选择,您可以使用表达式,但不能将值传递给存储过程。

于 2019-02-01T06:28:22.273 回答