關(guān)于if?exists的用法及說明
更新時間:2022年09月26日 14:09:45 作者:liessay
這篇文章主要介紹了關(guān)于if?exists的用法及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
1 判斷數(shù)據(jù)庫是否存在
if exists (select * from sys.databases where name = '數(shù)據(jù)庫名') ? ? drop database [數(shù)據(jù)庫名]
2 判斷表是否存在
if exists (select * from sysobjects where id = object_id(N'[表名]') and OBJECTPROPERTY(id, N'IsUserTable') = 1) ? ? drop table [表名]
3 判斷存儲過程是否存在
if exists (select * from sysobjects where id = object_id(N'[存儲過程名]') and OBJECTPROPERTY(id, N'IsProcedure') = 1) ? ? drop procedure [存儲過程名]
4 判斷臨時表是否存在
if object_id('tempdb..#臨時表名') is not null ? ?
? drop table #臨時表名5 判斷視圖是否存在
--SQL Server 2000 ?? IF EXISTS (SELECT * FROM sysviews WHERE object_id = '[dbo].[視圖名]' ? --SQL Server 2005 ?? IF EXISTS (SELECT * FROM sys.views WHERE object_id = '[dbo].[視圖名]' ?--SQL Server 2000 IF EXISTS (SELECT * FROM sysviews WHERE object_id = '[dbo].[視圖名]' --SQL Server 2005 IF EXISTS (SELECT * FROM sys.views WHERE object_id = '[dbo].[視圖名]'
6 判斷函數(shù)是否存在
-- ?判斷要創(chuàng)建的函數(shù)名是否存在 ? ? ? if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[函數(shù)名]') and xtype in (N'FN', N'IF', N'TF')) ? ? ? drop function [dbo].[函數(shù)名] ? ?-- ?判斷要創(chuàng)建的函數(shù)名是否存在 ?
7 獲取用戶創(chuàng)建的對象信息
SELECT [name],[id],crdate FROM sysobjects where xtype='U' ? /* ? xtype 的表示參數(shù)類型,通常包括如下這些 ? C = CHECK 約束 ? D = 默認(rèn)值或 DEFAULT 約束 ? F = FOREIGN KEY 約束 ? L = 日志 ? FN = 標(biāo)量函數(shù) ? IF = 內(nèi)嵌表函數(shù) ? P = 存儲過程 ? PK = PRIMARY KEY 約束(類型是 K) ? RF = 復(fù)制篩選存儲過程 ? S = 系統(tǒng)表 ? TF = 表函數(shù) ? TR = 觸發(fā)器 ? U = 用戶表 ? UQ = UNIQUE 約束(類型是 K) ? V = 視圖 ? X = 擴(kuò)展存儲過程*/
8 判斷列是否存在
if exists(select * from syscolumns where id=object_id('表名') and name='列名') ?
? alter table 表名 drop column 列名9 判斷列是否自增列
if columnproperty(object_id('table'),'col','IsIdentity')=1 ?
? print '自增列' ?
else ?
? print '不是自增列' ?10 判斷表中是否存在索引
if exists(select * from sysindexes where id=object_id('表名') and name='索引名') ? ?
? print ?'存在' ? ?
else ? ?
? print ?'不存在11 查看數(shù)據(jù)庫中對象
SELECT * FROM sys.sysobjects WHERE name='對象名'以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
SQL Server使用腳本實(shí)現(xiàn)自動備份的思路詳解
這篇文章主要介紹了SQL Server使用腳本實(shí)現(xiàn)自動備份的思路詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
SQL Server中數(shù)學(xué)函數(shù)的用法
這篇文章介紹了SQL Server中數(shù)學(xué)函數(shù)的用法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05
SQL Server 數(shù)據(jù)頁緩沖區(qū)的內(nèi)存瓶頸分析
數(shù)據(jù)頁緩存是SQL Server的內(nèi)存使用主要的方面,也是占用量最大的部分。在一個穩(wěn)定的DB Server上,這部分內(nèi)存使用會相對較穩(wěn)定2012-08-08
SQL Server 2012安裝后服務(wù)器名稱找不到的解決辦法
這篇文章主要介紹了SQL Server 2012安裝后服務(wù)器名稱找不到的解決辦法,需要的朋友可以參考下2016-10-10
刪除數(shù)據(jù)庫中重復(fù)數(shù)據(jù)的幾個方法
刪除數(shù)據(jù)庫中重復(fù)數(shù)據(jù)的幾個方法...2006-12-12
使用SQL Server數(shù)據(jù)庫嵌套子查詢的方法
使用SQL Server數(shù)據(jù)庫嵌套子查詢的方法...2007-03-03

