2

我正在尝试运行脚本以在 SQL Server 2008 r2 上设置 tsqlt 并收到此错误

“OBJECT_SCHEMA_NAME”不是可识别的内置函数名称。

在另一台装有 SQL 2008 r2 的机器上,脚本运行良好。

我看不到每台机器的 sql server 设置中的用户或权限有任何区别。

这是引发错误的语句:

    CREATE FUNCTION tSQLt.Private_GetOriginalTableInfo(@TableObjectId INT)
RETURNS TABLE
AS
  RETURN SELECT CAST(value AS NVARCHAR(4000)) OrgTableName,
    OBJECT_ID(QUOTENAME(OBJECT_SCHEMA_NAME(@TableObjectId)) 
    + '.' + QUOTENAME(CAST(value AS NVARCHAR(4000)))) OrgTableObjectId
    FROM sys.extended_properties
   WHERE class_desc = 'OBJECT_OR_COLUMN'
     AND major_id = @TableObjectId
     AND minor_id = 0
     AND name = 'tSQLt.FakeTable_OrgTableName';
GO
4

1 回答 1

2

如果这实际上是在 SQL Server 2008 R2 上,则您的数据库处于 SQL Server 2000 兼容模式。你可以知道你现在处于什么模式:

SELECT name, compatibility_level
  FROM sys.databases
  WHERE name = N'your_database';

如果这是 80,您将需要向上移动(但这需要测试):

ALTER DATABASE your_database SET COMPATIBILITY_LEVEL = 100;

如果你不能向上移动,那么你总是可以通过加入sys.schemas而不是依赖内置函数来获取模式名称。


也就是说,如果您使用的是 SQL Server 2005 RTM(如评论中所暗示的那样),OBJECT_SCHEMA_NAME则在 SQL Server 2005 Service Pack 2 中引入了。您不应再在 SQL Server 2005 RTM 上运行任何系统。去安装SP4,你就可以使用这个功能了。

于 2013-02-12T17:04:45.210 回答