一尘不染

如何检查 SQL Server 表中是否存在列?

javascript

如果它不存在,我需要添加一个特定的列。我有类似以下的内容,但它总是返回 false:

IF EXISTS(SELECT *
          FROM   INFORMATION_SCHEMA.COLUMNS
          WHERE  TABLE_NAME = 'myTableName'
                 AND COLUMN_NAME = 'myColumnName') 

如何检查 SQL Server 数据库的表中是否存在列?


阅读 194

收藏
2022-02-12

共2个答案

一尘不染

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

Martin Smith 的版本更短:

IF COL_LENGTH('schemaName.tableName', 'columnName') IS NOT NULL
BEGIN
    -- Column Exists
END
2022-02-12
一尘不染

更简洁的版本

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始终仅返回有关已提交更改的数据,而与有效的隔离级别无关。

2022-02-12