就像这样:
SELECT
*
FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS
WHERE CONSTRAINT_NAME ='FK_TreeNodesBinaryAssets_BinaryAssets'
and TABLE_NAME = 'TreeNodesBinaryAssets'
但是对于索引。
就像这样:
SELECT
*
FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS
WHERE CONSTRAINT_NAME ='FK_TreeNodesBinaryAssets_BinaryAssets'
and TABLE_NAME = 'TreeNodesBinaryAssets'
但是对于索引。
当前回答
EXEC sp_helpindex '[[[SCHEMA-NAME.TABLE-NAME]]]'
GO
其他回答
对于SQL 2008及更新版本,一个更简洁的方法,在编码方面,检测索引是否存在是使用INDEXPROPERTY内置函数:
INDEXPROPERTY ( object_ID , index_or_statistics_name , property )
最简单的用法是IndexID属性:
If IndexProperty(Object_Id('MyTable'), 'MyIndex', 'IndexID') Is Null
如果索引存在,则返回索引ID;如果没有,它将返回NULL。
EXEC sp_helpindex '[[[SCHEMA-NAME.TABLE-NAME]]]'
GO
-- Delete index if exists
IF EXISTS(SELECT TOP 1 1 FROM sys.indexes indexes INNER JOIN sys.objects
objects ON indexes.object_id = objects.object_id WHERE indexes.name
='Your_Index_Name' AND objects.name = 'Your_Table_Name')
BEGIN
PRINT 'DROP INDEX [Your_Index_Name] ON [dbo].[Your_Table_Name]'
DROP INDEX [our_Index_Name] ON [dbo].[Your_Table_Name]
END
GO
你可以像这样直接选择:
SELECT *
FROM sys.indexes
WHERE name='YourIndexName' AND object_id = OBJECT_ID('Schema.YourTableName')
然而,与最初的问题稍有偏差,可能会对将来想要DROP和CREATE索引的人有用,即在部署脚本中。
你可以通过在你的create语句中添加以下内容来绕过exists检查:
CREATE INDEX IX_IndexName
ON dbo.TableName
WITH (DROP_EXISTING = ON);
在这里阅读更多:CREATE INDEX (Transact-SQL) - DROP_EXISTING子句
注意:正如注释中提到的,索引必须已经存在,此子句才能正常工作而不抛出错误。