不是一个被识别的内置函数名。

49
创建了一个函数。
CREATE FUNCTION Split_On_Upper_Case(@Temp VARCHAR(1000))
RETURNS VARCHAR(1000)
AS
BEGIN
DECLARE @KeepValues AS VARCHAR(50)
SET @KeepValues='%[^ ][A-Z]%'
WHILE PATINDEX(@KeepValues COLLATE Latin1_General_Bin,@Temp)>0
SET @Temp=STUFF(@Temp,PATINDEX(@KeepValues COLLATE Latin1_General_Bin,@Temp)+1,0,' ')
RETURN @Temp
END

当我尝试执行以下命令 SELECT Split_On_Upper_Case('SaiBharath')时,会出现错误信息“'Split_On_Upper_Case' is not a recognized built-in function name."。请问有人能解释一下吗?


1
@Mansoor - 请? - Rich Benner
3个回答

79

在前缀中添加 [dbo],然后执行相同的操作:

SELECT [dbo].[Split_On_Upper_Case] ('SaiBharath')

12
好的回答不仅需要代码还需要一些解释。 - GuidoG
1
公平地说,微软似乎也没有提供太多的解释。这个答案已经足以解决我过去半个小时试图执行函数时的挫败感。 - Daniel Bradley
谢谢您的回答,但我想知道是否有避免使用dbo的方法?请参见我的问题:https://stackoverflow.com/questions/52953159/user-scalar-valued-function-without-the-dbo-part - Neil
即使这样也没有解决问题。我仍然收到“找不到函数”的错误,即使我已经重新连接了服务器并重新启动以刷新内存。谢谢。 - MindRoasterMir

13

在 SQL 中执行函数时,应使用前缀 dbo

SELECT [dbo].[Split_On_Upper_Case] ('SaiBharath')

9

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接