当我运行它时使用 SQL Server 2016:
SELECT *
FROM sys.indexes
WHERE name = 'idx_Parts_PartNum'
只有一个结果。不出所料。但是当我在同一个数据库上运行时:
exec sp_rename N'idx_Parts_PartNum', N'ux_Parts_PartNum', N'INDEX'
我收到这个错误:
Either the parameter @objname is ambiguous or the claimed @objtype (INDEX) is wrong.
如果第一个查询显示此索引名称是正确的,会导致此错误的原因是什么?
我在 Google 上搜索过,但没有成功。我的索引名称不包含无效字符或保留字。
注意:这是作为唯一索引创建的,不是唯一约束。
我可以使用 SQL Server Management Studio 重命名索引而不会出错。
最佳答案
您需要给出索引的完整路径,如example中所示在文档中:
CREATE TABLE dbo.YourTable (ID int);
GO
CREATE UNIQUE INDEX IX_YourIndex ON dbo.YourTable (ID);
GO
EXEC sp_rename N'dbo.YourTable.IX_YourIndex',N'UX_YourIndex','INDEX'; --Schema, Table, Index
GO
DROP TABLE dbo.YourTable;
关于sql-server - 参数@objname 不明确或声明的@objtype (INDEX) 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65129841/