SignByCert (Transact-SQL)
証明書を使用してテキストに署名し、その署名を返します。
構文
SignByCert( certificate_ID, @cleartext [,'password' ] )
引数
- certificate_ID
データベースに含まれる証明書の ID を指定します。 int.
- @cleartext
署名するデータを含む、nvarchar、char、varchar、または nchar 型の変数を指定します。
- 'password'
証明書の秘密キーを暗号化する場合に使用したパスワードを指定します。データ型は nvarchar(128) です。
戻り値の型
varbinary 型 (最大サイズは 8,000 バイト)。
解説
証明書に対する CONTROL 権限が必要です。
例
次の例では、証明書 ABerglundCert07
を使用して @SensitiveData
内のテキストに署名します。署名の前にはパスワード "pGFD4bb925DGvbd2439587y" を使用して証明書を暗号化解除します。その後、クリアテキストと署名をテーブル SignedData04
に挿入します。
DECLARE @SensitiveData nvarchar(max);
SET @SensitiveData = N'Saddle Price Points are
2, 3, 5, 7, 11, 13, 17, 19, 23, 29';
INSERT INTO [SignedData04]
VALUES( N'data signed by certificate ''ABerglundCert07''',
@SensitiveData, SignByCert( Cert_Id( 'ABerglundCert07' ),
@SensitiveData, N'pGFD4bb925DGvbd2439587y' ));
GO
参照
関連項目
VerifySignedByCert (Transact-SQL)
Cert_ID (Transact-SQL)
CREATE CERTIFICATE (Transact-SQL)
ALTER CERTIFICATE (Transact-SQL)
DROP CERTIFICATE (Transact-SQL)