一、前言概述
在写一些业务逻辑相对复杂点的存储过程的时候,经常会用到临时表或者数据表作为临时结果的保存。但每次在作表是否存在的判断时,往往想不起完整的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不存在'<