前言
在操作数据库的时候经常会用到判断数据表、视图、函数/方法、存储过程是否存在,若存在,则需要删除后再重新创建。以下是MS SQL Server中的示例代码。
数据表(Table)
创建数据表的时候判断数据表是否存在,若存在则删除,会经常使用,特别是初始化的时候。
--方法一/*判断数据表是否存在,若存在则删除数据表*/IF EXISTS (SELECT * FROM sys.objects WHERE name = 'Table_Name') DROP TABLE Table_Name;GO--创建数据表CREATE TABLE Table_Name( Id INT PRIMARY KEY NOT NULL)--方法二/*判断数据表是否存在,若存在则删除数据表*/IF EXISTS (SELECT * FROM dbo.sysobjects WHERE name = 'Table_Name') DROP VIEW Table_Name;GO--创建数据表CREATE TABLE Table_Name( Id INT PRIMARY KEY NOT NULL)
视图(View)
创建视图的时候判断视图是否存在,若存在则删除,会经常使用,特别是视图更改过后。
--方法一/*判断视图是否存在,若存在则删除视图*/IF EXISTS (SELECT * FROM sys.views WHERE name = 'View_Name') DROP VIEW View_Name GO--创建视图CREATE VIEW View_Name AS SELECT SELECT * FROM table_nameGO--方法二/*判断视图是否存在,若存在则删除视图*/IF EXISTS (SELECT * FROM sys.objects WHERE name = 'View_Name') DROP VIEW View_Name;GO--创建视图CREATE VIEW View_Name AS SELECT SELECT * FROM table_nameGO--方法三/*判断视图是否存在,若存在则删除视图*/IF EXISTS (SELECT * FROM dbo.sysobjects WHERE name = 'View_Name') DROP VIEW View_Name;GO--创建视图CREATE VIEW View_Name AS SELECT SELECT * FROM table_nameGO
函数/方法(Function)
创建函数/方法的时候判断函数/方法是否存在,若存在则删除,会经常使用,特别是函数/方法更改过后。
--方法一/*判断函数/方法是否存在,若存在则删除函数/方法*/IF EXISTS (SELECT * FROM sys.objects WHERE name = 'Func_Name') DROP FUNCTION Func_Name;GO--创建存储过程CREATE FUNCTION Func_Name( @a INT)RETURN INTASBEGIN--codingENDGO--方法二/*判断函数/方法是否存在,若存在则删除函数/方法*/IF EXISTS (SELECT * FROM dbo.sysobjects WHERE name = 'Func_Name') DROP FUNCTION Func_Name;GO--创建函数/方法CREATE FUNCTION Func_Name( @a INT)RETURN INTASBEGIN--codingENDGO
存储过程(Procedure)
创建存储过程的时候判存储过程是否存在,若存在则删除,会经常使用,特别是存储过程更改过后。
--方法一/*判断存储过程是否存在,若存在则删除存储过程*/IF EXISTS (SELECT * FROM sys.objects WHERE name = 'Proc_Name') DROP PROC Proc_Name;GO--创建存储过程CREATE PROC Proc_NameAS SELECT * FROM Table_NameGO--方法二/*判断存储过程是否存在,若存在则删除存储过程*/IF EXISTS (SELECT * FROM dbo.sysobjects WHERE name = 'Proc_Name') DROP PROC Proc_Name;GO--创建存储过程CREATE PROC Proc_NameAS SELECT * FROM Table_NameGO--方法三/*判断存储过程是否存在,若存在则删除存储过程*/IF EXISTS (OBJECT_NAME('Proc_Name','P') IS NOT NULL DROP PROC Proc_Name;GO--创建存储过程CREATE PROC Proc_NameAS SELECT * FROM Table_NameGO