第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何檢查SQLServer表中是否存在列?

如何檢查SQLServer表中是否存在列?

萬千封印 2019-07-04 18:18:11
如何檢查SQLServer表中是否存在列?我需要添加一個特定的列,如果它不存在。我有如下內(nèi)容,但它總是返回false:IF EXISTS(SELECT *           FROM   INFORMATION_SCHEMA.COLUMNS          WHERE  TABLE_NAME = 'myTableName'                  AND COLUMN_NAME = 'myColumnName')如何檢查SQLServer數(shù)據(jù)庫的表中是否存在列?
查看完整描述

3 回答

?
瀟瀟雨雨

TA貢獻1833條經(jīng)驗 獲得超4個贊

SQLServer 2005以后:

IF EXISTS(SELECT 1 FROM sys.columns 
          WHERE Name = N'columnName'
          AND Object_ID = Object_ID(N'schemaName.tableName'))BEGIN
    -- Column ExistsEND

馬丁·史密斯的版本更短:

IF COL_LENGTH('schemaName.tableName', 'columnName') IS NOT NULLBEGIN
    -- Column ExistsEND


查看完整回答
反對 回復(fù) 2019-07-04
?
函數(shù)式編程

TA貢獻1807條經(jīng)驗 獲得超9個贊

更簡潔的版本

IF COL_LENGTH('table_name','column_name') IS NULLBEGIN/* Column does not exist or caller does not have permission to view the object */END

關(guān)于查看元數(shù)據(jù)的權(quán)限的要點適用于所有答案,而不僅僅是這個答案。

注意,第一個參數(shù)表名為COL_LENGTH可以按要求采用一、二或三種部件名稱格式。

引用不同數(shù)據(jù)庫中的表的示例是

COL_LENGTH('AdventureWorks2012.HumanResources.Department','ModifiedDate')

與使用元數(shù)據(jù)視圖相比,此答案的一個不同之處是元數(shù)據(jù)函數(shù)(如COL_LENGTH無論有效隔離級別如何,始終只返回有關(guān)已提交更改的數(shù)據(jù)。


查看完整回答
反對 回復(fù) 2019-07-04
?
胡子哥哥

TA貢獻1825條經(jīng)驗 獲得超6個贊

根據(jù)您的具體要求調(diào)整以下內(nèi)容:

if not exists (select
                     column_name               from
                     INFORMATION_SCHEMA.columns               where
                     table_name = 'MyTable'
                     and column_name = 'MyColumn')
    alter table MyTable add MyColumn int

編輯以處理編輯到問題:這應(yīng)該有效-仔細檢查代碼中是否有愚蠢的錯誤;例如,您是在應(yīng)用INSERT的同一個數(shù)據(jù)庫上查詢Information_Schema嗎?在這兩種語句中,表/列名中是否都有錯誤?


查看完整回答
反對 回復(fù) 2019-07-04
  • 3 回答
  • 0 關(guān)注
  • 2200 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號