SQL Server 2012 Express でスケーラー UDF (sCurrentAppUser() と呼ばれる) を作成しました。テーブルを定義するときに、この UDF を既定値として使用したいと考えています。しかし、試行するたびに、「'sCurrentAppUser' は認識された組み込み関数名ではありません」というエラーが表示されます。
まだ 2 つ以上のリンクを投稿できないので (評判)、私の研究と参考文献へのリンクをコメントに記載します。
ここに私のUDFがあります:
ALTER FUNCTION [dbo].[sCurrentAppUser] ()
RETURNS nVarChar(128)
AS BEGIN
DECLARE @CurrentAppUser nVarChar(128)
IF EXISTS (SELECT 1 FROM ActiveConnections WHERE ComputerName = host_name ()) BEGIN
SELECT @CurrentAppUser = CONVERT (nVarChar(128), LoginUser)
FROM ActiveConnections
WHERE ComputerName = host_name ()
END ELSE BEGIN
SELECT @CurrentAppUser = Convert (nVarChar(128), suser_sname ())
WHERE NOT EXISTS (
SELECT 1
FROM ActiveConnections
WHERE ComputerName = host_name ()
)
END
RETURN @CurrentAppUser
END
そして、最初の列にデフォルトの制約を付けてテーブルを作成しようとしました:
CREATE TABLE [dbo].[Clients](
[ModifyingUser] [nvarchar](128) NOT NULL DEFAULT sCurrentAppUser (),
[Modification] [char](1) NULL DEFAULT 'A',
[ModifyingHost] [nvarchar](128) NOT NULL DEFAULT host_name (),
[ClientID] [uniqueidentifier] NOT NULL,
[Label] [nvarchar](1024) NULL,
CONSTRAINT [PK_Clients] PRIMARY KEY (
[ClientID] ASC
)
)