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

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

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

瀏覽:229日期: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
主站蜘蛛池模板: 模型公司_模型制作_沙盘模型报价-中国模型网 | 整车VOC采样环境舱-甲醛VOC预处理舱-多舱法VOC检测环境仓-上海科绿特科技仪器有限公司 | 昆山新莱洁净应用材料股份有限公司-卫生级蝶阀,无菌取样阀,不锈钢隔膜阀,换向阀,离心泵 | 考勤系统_考勤管理系统_网络考勤软件_政企|集团|工厂复杂考勤工时统计排班管理系统_天时考勤 | 杜康白酒加盟_杜康酒代理_杜康酒招商加盟官网_杜康酒厂加盟总代理—杜康酒神全国运营中心 | 广州各区危化证办理_危险化学品经营许可证代办| 新能源汽车教学设备厂家报价[汽车教学设备运营18年]-恒信教具 | 衢州装饰公司|装潢公司|办公楼装修|排屋装修|别墅装修-衢州佳盛装饰 | 乐之康护 - 专业护工服务平台,提供医院陪护-居家照护-居家康复 | 中细软知识产权_专业知识产权解决方案提供商| 恒温振荡混匀器-微孔板振荡器厂家-多管涡旋混匀器厂家-合肥艾本森(www.17world.net) | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 精密交叉滚子轴承厂家,转盘轴承,YRT转台轴承-洛阳千协轴承 | 上海新光明泵业制造有限公司-电动隔膜泵,气动隔膜泵,卧式|立式离心泵厂家 | GAST/BRIWATEC/CINCINNATI/KARL-KLEIN/ZIEHL-ABEGG风机|亚喜科技 | 冲锋衣滑雪服厂家-冲锋衣定制工厂-滑雪服加工厂-广东睿牛户外(S-GERT) | 档案密集架,移动密集架,手摇式密集架,吉林档案密集架-厂家直销★价格公道★质量保证 | 半容积式换热器_北京浮动盘管换热器厂家|北京亿丰上达 | 地脚螺栓_材质_标准-永年县德联地脚螺栓厂家 | 车辆定位管理系统_汽车GPS系统_车载北斗系统 - 朗致物联 | 单级/双级旋片式真空泵厂家,2xz旋片真空泵-浙江台州求精真空泵有限公司 | QQ房产导航-免费收录优秀房地产网站_房地产信息网 | ?水马注水围挡_塑料注水围挡_防撞桶-常州瑞轩水马注水围挡有限公司 | 自清洗过滤器,浅层砂过滤器,叠片过滤器厂家-新乡市宇清净化 | 猎头招聘_深圳猎头公司_知名猎头公司| 球磨机,节能球磨机价格,水泥球磨机厂家,粉煤灰球磨机-吉宏机械制造有限公司 | 安徽免检低氮锅炉_合肥燃油锅炉_安徽蒸汽发生器_合肥燃气锅炉-合肥扬诺锅炉有限公司 | 洁净化验室净化工程_成都实验室装修设计施工_四川华锐净化公司 | 等离子空气净化器_医用空气消毒机_空气净化消毒机_中央家用新风系统厂家_利安达官网 | 德州网站制作 - 网站建设设计 - seo排名优化 -「两山建站」 | 进口试验机价格-进口生物材料试验机-西安卡夫曼测控技术有限公司 | 单电机制砂机,BHS制砂机,制沙机设备,制砂机价格-正升制砂机厂家 单级/双级旋片式真空泵厂家,2xz旋片真空泵-浙江台州求精真空泵有限公司 | 天助网 - 中小企业全网推广平台_生态整合营销知名服务商_天助网采购优选 | 中图网(原中国图书网):网上书店,尾货特色书店,30万种特价书低至2折! | 欧洲MV日韩MV国产_人妻无码一区二区三区免费_少妇被 到高潮喷出白浆av_精品少妇自慰到喷水AV网站 | PVC地板|PVC塑胶地板|PVC地板厂家|地板胶|防静电地板-无锡腾方装饰材料有限公司-咨询热线:4008-798-128 | 安徽合肥项目申报咨询公司_安徽合肥高新企业项目申报_安徽省科技项目申报代理 | 耐酸碱胶管_耐腐蚀软管总成_化学品输送软管_漯河利通液压科技耐油耐磨喷砂软管|耐腐蚀化学软管 | 石英粉,滑石粉厂家,山东滑石粉-莱州市向阳滑石粉有限公司 | 雷冲击高压发生器-水内冷直流高压发生器-串联谐振分压器-武汉特高压电力科技有限公司 | 一体式钢筋扫描仪-楼板测厚仪-裂缝检测仪-泰仕特(北京) |