这篇文章主要介绍了SQLServer怎么判断数据库、表、列、视图、存储过程、函数是否存在的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SQLServer怎么判断数据库、表、列、视图、存储过程、函数是否存在文章都会有所收获,下面我们一起来看看吧。
一、数据库相关的判断
判断数据库是否存在
IF EXISTS (SELECT * FROM sys.databases WHERE NAME='TEST') PRINT '数据库TEST存在' ELSE PRINT '数据库TEST不存在'
二、数据表相关的判断
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不存在'
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、判断表是否存在某列
--方法一 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'
三、视图相关的判断
判断视图是否存在
--方法一 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不存在'
四、存储过程相关的判断
判断存储过程是否存在
--方法一 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不存在'
五、函数相关的判断
判断函数是否存在
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不存在'