电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

SQL Server判斷數據庫、表、列、視圖、存儲過程、函數是否存在總結

瀏覽:232日期:2023-05-02 10:03:15
目錄
  • 一、前言概述
  • 二、數據庫相關的判斷
    • 2.1、判斷數據庫是否存在
  • 三、數據表相關的判斷
    • 3.1、判斷數據表是否存在
    • 3.2、判斷臨時表是否存在
    • 3.3、判斷表是否存在某列
    • 3.4、判斷列是否自增列
    • 3.5、判斷表中是否存在索引
  • 四、視圖相關的判斷
    • 4.1、判斷視圖是否存在
  • 五、存儲過程相關的判斷
    • 5.1、判斷存儲過程是否存在
  • 六、函數相關的判斷
    • 6.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不存在"

到此這篇關于SQL Server判斷數據庫、表、列、視圖、存儲過程、函數是否存在的文章就介紹到這了,更多相關sqlserver判斷視圖函數內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MsSQL
主站蜘蛛池模板: 北京开源多邦科技发展有限公司官网 | 网站seo优化_seo云优化_搜索引擎seo_启新网络服务中心 | 整车VOC采样环境舱-甲醛VOC预处理舱-多舱法VOC检测环境仓-上海科绿特科技仪器有限公司 | BOE画框屏-触摸一体机-触控查询一体机-触摸屏一体机价格-厂家直销-触发电子 | 智慧农业|农业物联网|现代农业物联网-托普云农物联网官方网站 | 深圳宣传片制作_产品视频制作_深圳3D动画制作公司_深圳短视频拍摄-深圳市西典映画传媒有限公司 | 防水套管厂家-柔性防水套管-不锈钢|刚性防水套管-天翔管道 | 盛源真空泵|空压机-浙江盛源空压机制造有限公司-【盛源官网】 | 耐压仪-高压耐压仪|徐吉电气| 紧急泄压人孔_防爆阻火器_阻火呼吸阀[河北宏泽石化] | 锂离子电池厂家-山东中信迪生电源| 头条搜索极速版下载安装免费新版,头条搜索极速版邀请码怎么填写? - 欧远全 | 聚氨酯保温钢管_聚氨酯直埋保温管道_聚氨酯发泡保温管厂家-沧州万荣防腐保温管道有限公司 | 垃圾处理设备_餐厨垃圾处理设备_厨余垃圾处理设备_果蔬垃圾处理设备-深圳市三盛环保科技有限公司 | 超声波乳化机-超声波分散机|仪-超声波萃取仪-超声波均质机-精浩机械|首页 | 飞象网 - 通信人每天必上的网站 全球化工设备网—化工设备,化工机械,制药设备,环保设备的专业网络市场。 | 油冷式_微型_TDY电动滚筒_外装_外置式电动滚筒厂家-淄博秉泓机械有限公司 | 烽火安全网_加密软件、神盾软件官网| 2-羟基泽兰内酯-乙酰蒲公英萜醇-甘草查尔酮A-上海纯优生物科技有限公司 | 不锈钢螺丝,不锈钢螺栓,不锈钢标准件-江苏百德特种合金有限公司 交变/复合盐雾试验箱-高低温冲击试验箱_安奈设备产品供应杭州/江苏南京/安徽马鞍山合肥等全国各地 | 全球化工设备网—化工设备,化工机械,制药设备,环保设备的专业网络市场。 | 吉林污水处理公司,长春工业污水处理设备,净水设备-长春易洁环保科技有限公司 | 洛阳网站建设_洛阳网站优化_网站建设平台_洛阳香河网络科技有限公司 | 电子海图系统-电梯检验系统-智慧供热系统开发-商品房预售资金监管系统 | 上海璟文空运首页_一级航空货运代理公司_机场快递当日达 | 耐热钢-耐磨钢-山东聚金合金钢铸造有限公司 | 深圳高新投三江工业消防解决方案提供厂家_服务商_园区智慧消防_储能消防解决方案服务商_高新投三江 | 兰州UPS电源,兰州山特UPS-兰州万胜商贸 | 全自动定氮仪-半自动凯氏定氮仪厂家-祎鸿仪器 | 长沙广告公司|长沙广告制作设计|长沙led灯箱招牌制作找望城湖南锦蓝广告装饰工程有限公司 | 户外-组合-幼儿园-不锈钢-儿童-滑滑梯-床-玩具-淘气堡-厂家-价格 | Eiafans.com_环评爱好者 环评网|环评论坛|环评报告公示网|竣工环保验收公示网|环保验收报告公示网|环保自主验收公示|环评公示网|环保公示网|注册环评工程师|环境影响评价|环评师|规划环评|环评报告|环评考试网|环评论坛 - Powered by Discuz! | 次氯酸钠厂家,涉水级次氯酸钠,三氯化铁生产厂家-淄博吉灿化工 | 汝成内控-行政事业单位内部控制管理服务商| 厚壁钢管-厚壁无缝钢管-小口径厚壁钢管-大口径厚壁钢管 - 聊城宽达钢管有限公司 | 安徽集装箱厂-合肥国彩钢结构板房工程有限公司 | 传递窗_超净|洁净工作台_高效过滤器-传递窗厂家广州梓净公司 | 硫酸钡厂家_高光沉淀硫酸钡价格-河南钡丰化工有限公司 | 广西资质代办_建筑资质代办_南宁资质代办理_新办、增项、升级-正明集团 | 贴片电感_贴片功率电感_贴片绕线电感_深圳市百斯特电子有限公司 贴片电容代理-三星电容-村田电容-风华电容-国巨电容-深圳市昂洋科技有限公司 | 玻纤土工格栅_钢塑格栅_PP焊接_单双向塑料土工格栅_复合防裂布厂家_山东大庚工程材料科技有限公司 |