这篇文章主要介绍了SQLServer判断数据库、表、列、视图、存储过程、函数是否存在,本文是一篇总结篇,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
一、前言概述
在写一些业务逻辑相对复杂点的存储过程的时候,经常会用到临时表或者数据表作为临时结果的保存。但每次在作表是否存在的判断时,往往想不起完整的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不存在'
到此这篇关于SQL Server判断数据库、表、列、视图、存储过程、函数是否存在的文章就介绍到这了,更多相关sqlserver判断视图函数内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
沃梦达教程
本文标题为:SQL Server判断数据库、表、列、视图、存储过程、函数是否存在总结
猜你喜欢
- MySQL8.0.28安装教程详细图解(windows 64位) 2023-07-26
- Oracle 删除大量表记录操作分析总结 2023-07-23
- Numpy中如何创建矩阵并等间隔抽取数据 2023-07-28
- Mongodb启动报错完美解决方案:about to fork child process,waiting until server is ready for connections. 2023-07-16
- 在阿里云CentOS 6.8上安装Redis 2023-09-12
- SQL Server 2022 AlwaysOn新特性之包含可用性组详解 2023-07-29
- 基于Python制作一个简单的文章搜索工具 2023-07-28
- redis清除数据 2023-09-13
- 搭建单机Redis缓存服务的实现 2023-07-13
- SQLSERVER调用C#的代码实现 2023-07-29