一、前言概述 在寫一些業務邏輯相對複雜點的存儲過程的時候,經常會用到臨時表或者數據表作為臨時結果的保存。但每次在作表是否存在的判斷時,往往想不起完整的SQL寫法。因此,記錄一些常用的資料庫對象是否存在的判斷方法,可以達到快速查找的目的。正是:好記性不如爛筆頭。 二、資料庫相關的判斷 2.1、判斷數據 ...
一、前言概述
在寫一些業務邏輯相對複雜點的存儲過程的時候,經常會用到臨時表或者數據表作為臨時結果的保存。但每次在作表是否存在的判斷時,往往想不起完整的SQL寫法。因此,記錄一些常用的資料庫對象是否存在的判斷方法,可以達到快速查找的目的。正是:好記性不如爛筆頭。
二、資料庫相關的判斷
2.1、判斷資料庫是否存在
IF EXISTS (SELECT * FROM sys.databases WHERE NAME='TEST') PRINT '資料庫TEST存在' ELSE PRINT '資料庫TEST不存在'
三、數據表相關的判斷
3.1、判斷數據表是否存在
--方法一 IF OBJECT_ID(N'[dbo].[PRODUCT]',N'U') IS NOT NULL PRINT '數據表PRODUCT存在' ELSE PRINT '數據表PRODUCT不存在' --方法二 IF EXISTS (SELECT * FROM sysobjects WHERE ID=OBJECT_ID(N'[dbo].[PRODUCT]') AND XTYPE='U') PRINT '數據表PRODUCT存在' ELSE PRINT '數據表PRODUCT不存在' --方法三 IF EXISTS (SELECT * FROM sysobjects WHERE ID=OBJECT_ID(N'[dbo].[PRODUCT]') AND OBJECTPROPERTY(ID,N'IsUserTable')=1) PRINT '數據表PRODUCT存在' ELSE PRINT '數據表PRODUCT不存在'
3.2、判斷臨時表是否存在
--方法一 IF OBJECT_ID(N'tempdb..#PRODUCT',N'U') IS NOT NULL PRINT '臨時表#PRODUCT存在' ELSE PRINT '臨時表#PRODUCT不存在' --方法二 IF EXISTS (SELECT * FROM tempdb.dbo.sysobjects WHERE ID=OBJECT_ID(N'tempdb..#PRODUCT') AND XTYPE='U') PRINT '臨時表#PRODUCT存在' ELSE PRINT '臨時表#PRODUCT不存在'
3.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'
3.4、判斷列是否自增列
IF COLUMNPROPERTY(OBJECT_ID(N'[dbo].[PRODUCT]'),'PRD_ID','ISIDENTITY')=1 PRINT '表PRODUCT列PRD_ID是自增列' ELSE PRINT '表PRODUCT列PRD_ID不是自增列'
3.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'
四、視圖相關的判斷
4.1、判斷視圖是否存在
--方法一 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不存在'
五、存儲過程相關的判斷
5.1、判斷存儲過程是否存在
--方法一 IF OBJECT_ID(N'[dbo].[BRC_BomCost]','P') IS NOT NULL PRINT '存儲過程BRC_BomCost存在' ELSE PRINT '存儲過程BRC_BomCost不存在' --方法二 IF EXISTS (SELECT * FROM sysobjects WHERE ID=OBJECT_ID(N'[dbo].[BRC_BomCost]') AND OBJECTPROPERTY(ID,N'IsProcedure')=1) PRINT '存儲過程BRC_BomCost存在' ELSE PRINT '存儲過程BRC_BomCost不存在'
六、函數相關的判斷
6.1、判斷函數是否存在
IF EXISTS (SELECT * FROM sysobjects WHERE ID=OBJECT_ID(N'[dbo].[BRC_MLTotal]') AND XTYPE IN (N'FN',N'IF',N'TF')) PRINT '函數BRC_MLTotal存在' ELSE PRINT '函數BRC_MLTotal不存在'