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

如果它不存在,我需要添加一个特定的列。 我有这样的事情,但总是返回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这样的元数据函数始终只会返回有关已提交更改的数据,而与隔离级别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? 两种语句中的表/列名称中是否有拼写错误?

链接地址: http://www.djcxy.com/p/2757.html

上一篇: How to check if a column exists in a SQL Server table?

下一篇: How to return only the Date from a SQL Server DateTime datatype