web-dev-qa-db-ja.com

認識される組み込み関数名ではありません

関数を作成しました

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

IamがこのSELECT Split_On_Upper_Case('SaiBharath')を実行しようとすると、「 'Split_On_Upper_Case'は認識されている組み込み関数名ではありません。」というエラーが表示されます。

22
sai bharath

プレフィックスに[dbo]を追加して、同じように実行します。

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

SQLで関数を実行するには、接頭辞dboを使用する必要があります。

SELECT [dbo].[Split_On_Upper_Case] ('SaiBharath')
11
Ravi Matani

念のため、最初にuse句を使用して関数を作成したデータベースを設定し、関数の呼び出しの前にdboを付けます。

USE <DatabaseName>

SELECT dbo.Split_On_Upper_Case('camelCase')

また、良い習慣は その問題のために各関数またはデータベースオブジェクトをそのスキーマ名でプレフィックスする です。

8
Radu Gheorghiu