溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》
  • 首頁 > 
  • 教程 > 
  • 開發(fā)技術(shù) > 
  • SQLServer怎么判斷數(shù)據(jù)庫、表、列、視圖、存儲(chǔ)過程、函數(shù)是否存在

SQLServer怎么判斷數(shù)據(jù)庫、表、列、視圖、存儲(chǔ)過程、函數(shù)是否存在

發(fā)布時(shí)間:2023-05-05 11:16:04 來源:億速云 閱讀:127 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了SQLServer怎么判斷數(shù)據(jù)庫、表、列、視圖、存儲(chǔ)過程、函數(shù)是否存在的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇SQLServer怎么判斷數(shù)據(jù)庫、表、列、視圖、存儲(chǔ)過程、函數(shù)是否存在文章都會(huì)有所收獲,下面我們一起來看看吧。

一、數(shù)據(jù)庫相關(guān)的判斷

判斷數(shù)據(jù)庫是否存在

IF EXISTS (SELECT * FROM sys.databases WHERE NAME='TEST')
    PRINT '數(shù)據(jù)庫TEST存在'
ELSE
    PRINT '數(shù)據(jù)庫TEST不存在'

二、數(shù)據(jù)表相關(guān)的判斷

1、判斷數(shù)據(jù)表是否存在

--方法一
IF OBJECT_ID(N'[dbo].[PRODUCT]',N'U') IS NOT NULL
    PRINT '數(shù)據(jù)表PRODUCT存在'
ELSE
    PRINT '數(shù)據(jù)表PRODUCT不存在'
--方法二
IF EXISTS (SELECT * FROM sysobjects WHERE ID=OBJECT_ID(N'[dbo].[PRODUCT]') AND XTYPE='U')
    PRINT '數(shù)據(jù)表PRODUCT存在'
ELSE
    PRINT '數(shù)據(jù)表PRODUCT不存在'
--方法三
IF EXISTS (SELECT * FROM sysobjects WHERE ID=OBJECT_ID(N'[dbo].[PRODUCT]') AND OBJECTPROPERTY(ID,N'IsUserTable')=1)
    PRINT '數(shù)據(jù)表PRODUCT存在'
ELSE
    PRINT '數(shù)據(jù)表PRODUCT不存在'

2、判斷臨時(shí)表是否存在

--方法一
IF OBJECT_ID(N'tempdb..#PRODUCT',N'U') IS NOT NULL
    PRINT '臨時(shí)表#PRODUCT存在'
ELSE
    PRINT '臨時(shí)表#PRODUCT不存在'
--方法二
IF EXISTS (SELECT * FROM tempdb.dbo.sysobjects WHERE ID=OBJECT_ID(N'tempdb..#PRODUCT') AND XTYPE='U')
    PRINT '臨時(shí)表#PRODUCT存在'
ELSE
    PRINT '臨時(shí)表#PRODUCT不存在'

3、判斷表是否存在某列

--方法一
IF COL_LENGTH(N'[dbo].[PRODUCT]','PRD_ID') IS NOT NULL
    PRINT '表PRODUCT存在列PRD_ID'
ELSE
    PRINT '表PRODUCT不存在列PRD_ID'
--方法二
IF EXISTS (SELECT * FROM syscolumns WHERE ID=OBJECT_ID(N'[dbo].[PRODUCT]') AND NAME='PRD_ID')
    PRINT '表PRODUCT存在列PRD_ID'
ELSE
    PRINT '表PRODUCT不存在列PRD_ID'
--方法三
IF EXISTS (SELECT * FROM sysobjects A INNER JOIN syscolumns B ON A.ID=B.ID WHERE A.XTYPE='U' AND A.NAME='PRODUCT' AND B.NAME='PRD_ID')
    PRINT '表PRODUCT存在列PRD_ID'
ELSE
    PRINT '表PRODUCT不存在列PRD_ID'

4、判斷列是否自增列

IF COLUMNPROPERTY(OBJECT_ID(N'[dbo].[PRODUCT]'),'PRD_ID','ISIDENTITY')=1
    PRINT '表PRODUCT列PRD_ID是自增列'
ELSE
    PRINT '表PRODUCT列PRD_ID不是自增列'

5、判斷表中是否存在索引

IF EXISTS(SELECT * FROM SYSINDEXES WHERE ID=OBJECT_ID(N'[dbo].[PRODUCT]') AND NAME='PK_PRODUCTS')
    PRINT '表PRODUCT存在索引PK_PRODUCTS'
ELSE
    PRINT '表PRODUCT不存在索引PK_PRODUCTS'

三、視圖相關(guān)的判斷

判斷視圖是否存在

--方法一
IF OBJECT_ID(N'[dbo].[BRC_1001]','V') IS NOT NULL
    PRINT '視圖BRC_1001存在'
ELSE
    PRINT '視圖BRC_1001不存在'
--方法二
IF EXISTS (SELECT * FROM sysobjects where id=OBJECT_ID(N'[dbo].[BRC_1001]') and OBJECTPROPERTY(ID,N'IsView')=1)
    PRINT '視圖BRC_1001存在'
ELSE
    PRINT '視圖BRC_1001不存在'
--方法三
IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.VIEWS WHERE TABLE_NAME=N'BRC_1001')
    PRINT '視圖BRC_1001存在'
ELSE
    PRINT '視圖BRC_1001不存在'

四、存儲(chǔ)過程相關(guān)的判斷

判斷存儲(chǔ)過程是否存在

--方法一
IF OBJECT_ID(N'[dbo].[BRC_BomCost]','P') IS NOT NULL
    PRINT '存儲(chǔ)過程BRC_BomCost存在'
ELSE
    PRINT '存儲(chǔ)過程BRC_BomCost不存在'
--方法二
IF EXISTS (SELECT * FROM sysobjects WHERE ID=OBJECT_ID(N'[dbo].[BRC_BomCost]') AND OBJECTPROPERTY(ID,N'IsProcedure')=1)
    PRINT '存儲(chǔ)過程BRC_BomCost存在'
ELSE
    PRINT '存儲(chǔ)過程BRC_BomCost不存在'

五、函數(shù)相關(guān)的判斷

判斷函數(shù)是否存在

IF EXISTS (SELECT * FROM sysobjects WHERE ID=OBJECT_ID(N'[dbo].[BRC_MLTotal]') AND XTYPE IN (N'FN',N'IF',N'TF'))
    PRINT '函數(shù)BRC_MLTotal存在'
ELSE
    PRINT '函數(shù)BRC_MLTotal不存在'

關(guān)于“SQLServer怎么判斷數(shù)據(jù)庫、表、列、視圖、存儲(chǔ)過程、函數(shù)是否存在”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“SQLServer怎么判斷數(shù)據(jù)庫、表、列、視圖、存儲(chǔ)過程、函數(shù)是否存在”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI