我知道这一定很简单,但是我如何在创建函数前加上检查以确定它是否已经存在?如果它存在,我想删除并重新创建它。
答案 0 :(得分:169)
IF EXISTS (
SELECT * FROM sysobjects WHERE id = object_id(N'function_name')
AND xtype IN (N'FN', N'IF', N'TF')
)
DROP FUNCTION function_name
GO
如果你想避免使用sys *表,你可以改为(来自例子A中的here):
IF object_id(N'function_name', N'FN') IS NOT NULL
DROP FUNCTION function_name
GO
要抓住的主要内容是您要删除的函数类型(在FN,IF和TF的顶部sql中表示):
答案 1 :(得分:22)
if object_id('FUNCTION_NAME') is not NULL
DROP FUNCTION <name>
您还可以在sysobjects中查看名称
IF EXISTS (SELECT *
FROM sysobjects
WHERE name='<function name>' and xtype='FN'
实际上,如果函数可以是表函数,则需要使用
xtype in ('FN','TF')
答案 2 :(得分:10)
这适用于任何对象,而不仅仅是函数:
IF OBJECT_ID('YourObjectName') IS NOT NULL
然后只需添加你的对象味道,如:
IF OBJECT_ID('YourFunction') IS NOT NULL
DROP FUNCTION YourFunction
答案 3 :(得分:7)
您有两个选项可以在SQL Server 2016中删除并重新创建该过程。
从SQL Server 2016开始 - 使用“IF EXISTS”
DROP FUNCTION [ IF EXISTS ] { [ schema_name. ] function_name } [ ,...n ]
[;]
从SQL Server 2016 SP1开始 - 使用“OR ALTER”
CREATE [ OR ALTER ] FUNCTION [ schema_name. ] function_name
答案 4 :(得分:5)
IF EXISTS
(SELECT * FROM sys.objects
WHERE object_id = OBJECT_ID(N'functionName')
AND type in (N'FN', N'IF', N'TF', N'FS', N'FT'))
DROP FUNCTION functionName
GO
答案 5 :(得分:2)
我通常回避来自sys *类型表的查询,供应商倾向于在发行版之间更改这些,主要或其他。我一直做的是发出DROP FUNCTION <name>
语句,而不用担心可能出现的任何SQL错误。我认为DBA领域的标准程序。
答案 6 :(得分:0)
IF EXISTS
(SELECT *
FROM schema.sys.objects
WHERE name = 'func_name')
DROP FUNCTION [dbo].[func_name]
GO
答案 7 :(得分:0)
从SQL Server 2016 CTP3
您可以使用新的 DIE 语句而不是大IF
包装
语法:
DROP FUNCTION [IF EXISTS] {[schema_name。 ] function_name} [,... n ]
查询:
DROP Function IF EXISTS udf_name
更多信息here
答案 8 :(得分:0)
以下是我对此的看法:
if(object_id(N'[dbo].[fn_Nth_Pos]', N'FN')) is not null
drop function [dbo].[fn_Nth_Pos];
GO
CREATE FUNCTION [dbo].[fn_Nth_Pos]
(
@find char, --char to find
@search varchar(max), --string to process
@nth int --occurrence
)
RETURNS int
AS
BEGIN
declare @pos int --position of nth occurrence
--init
set @pos = 0
while(@nth > 0)
begin
set @pos = charindex(@find,@search,@pos+1)
set @nth = @nth - 1
end
return @pos
END
GO
--EXAMPLE
declare @files table(name varchar(max));
insert into @files(name) values('abc_1_2_3_4.gif');
insert into @files(name) values('zzz_12_3_3_45.gif');
select
f.name,
dbo.fn_Nth_Pos('_', f.name, 1) as [1st],
dbo.fn_Nth_Pos('_', f.name, 2) as [2nd],
dbo.fn_Nth_Pos('_', f.name, 3) as [3rd],
dbo.fn_Nth_Pos('_', f.name, 4) as [4th]
from
@files f;
答案 9 :(得分:0)
检查IF是否存在功能
IF EXISTS (SELECT TOP 1 1 FROM sys.objects WHERE
object_id = OBJECT_ID(N'[Schema].[function_Name]')
AND type in (N'FN', N'IF', N'TF', N'FS', N'FT'))
BEGIN
DROP FUNCTION [Schema].[function_Name]
Print('function dropped => [Schema].[function_Name]')
END
GO
通过点击以下链接http://www.gurujipoint.com/2017/05/check-if-exist-for-trigger-function-and.html
检查存在过程的IF存在,功能答案 10 :(得分:0)
如果要使用SQL ISO标准INFORMATION_SCHEMA而不是SQL Server特定的sysobjects
,可以执行以下操作:
IF EXISTS (
SELECT ROUTINE_NAME FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_NAME = N'FunctionName'
)
DROP FUNCTION [dbo].[FunctionName]
GO