如果不存在,我需要添加一个特定的列。我有类似以下内容,但它总是返回 false:
IF EXISTS(SELECT *
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'myTableName'
AND COLUMN_NAME = 'myColumnName')
如何检查 SQL Server 数据库的表中是否存在列?
SQL Server 2005 以后:
IF EXISTS(SELECT 1 FROM sys.columns
WHERE Name = N'columnName'
AND Object_ID = Object_ID(N'schemaName.tableName'))
BEGIN
-- Column Exists
END
马丁史密斯的版本更短:
IF COL_LENGTH('schemaName.tableName', 'columnName') IS NOT NULL
BEGIN
-- Column Exists
END
更简洁的版本
IF COL_LENGTH('table_name','column_name') IS NULL
BEGIN
/*Column does not exist or caller does not have permission to view the object*/
END
关于查看元数据的权限的观点适用于所有答案,而不仅仅是这个答案。
请注意, COL_LENGTH
的第一个参数表名称可以根据需要采用一个,两个或三个部分名称格式。
引用不同数据库中的表的示例是
COL_LENGTH('AdventureWorks2012.HumanResources.Department','ModifiedDate')
与使用元数据视图相比,此答案的一个不同之处在于,无论有效的隔离级别如何, COL_LENGTH
等元数据函数始终只返回有关已提交更改的数据。
调整以下内容以满足您的特定要求:
if not exists (select
column_name
from
INFORMATION_SCHEMA.columns
where
table_name = 'MyTable'
and column_name = 'MyColumn')
alter table MyTable add MyColumn int
编辑处理编辑问题 :这应该工作 - 仔细查看代码中的愚蠢错误; 你在同一数据库中查询 INFORMATION_SCHEMA,例如你的插入被应用?在任何一个语句中,您的表 / 列名称都有拼写错误吗?