首页 > 资讯列表 > 编程/数据库 >> 数据库操作教程

SQL Server判断数据库、表、列、视图、存储过程、函数是否存在总结

数据库操作教程 2023-05-12 12:11:57 转载来源: 网络整理/侵权必删

英文:SQL  Server judges whether there is summary for database, table, column, view, stored procedure and function

目录一、前言概述二、数据库相关的判断2.1、判断数据库是否存在三、数据表相关的判断3

一、前言概述

在写一些业务逻辑相对复杂点的存储过程的时候,经常会用到临时表或者数据表作为临时结果的保存。但每次在作表是否存在的判断时,往往想不起完整的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 judges whether there is summary for database, table, column, view, stored procedure and function

标签: SQL nbsp Server 判断 数据库 视图 存储 过程 函数


声明:本文内容来源自网络,文字、图片等素材版权属于原作者,平台转载素材出于传递更多信息,文章内容仅供参考与学习,切勿作为商业目的使用。如果侵害了您的合法权益,请您及时与我们联系,我们会在第一时间进行处理!我们尊重版权,也致力于保护版权,站搜网感谢您的分享!

站长搜索

http://www.adminso.com

Copyright @ 2007~2024 All Rights Reserved.

Powered By 站长搜索

打开手机扫描上面的二维码打开手机版


使用手机软件扫描微信二维码

关注我们可获取更多热点资讯

站长搜索目录系统技术支持