SignByAsymKey (Transact-SQL)

非対称キーを使用してプレーン テキストに署名します。

トピック リンク アイコンTransact-SQL 構文表記規則

構文

SignByAsymKey( Asym_Key_ID , @plaintext [ , 'password' ] )

引数

  • Asym_Key_ID
    現在のデータベース内の非対称キーの ID を指定します。Asym_Key_ID のデータ型はint です。

  • @plaintext
    非対称キーを使って署名するデータを含む、nvarchar、char、varchar、または nchar 型の変数を指定します。

  • password
    秘密キーを保護するパスワードを指定します。password のデータ型は nvarchar(128) です。

戻り値の型

varbinary 型 (最大サイズは 8,000 バイト)

説明

非対称キーに対する CONTROL 権限が必要です。

次の例では、プレーン テキストとその署名を格納するテーブル SignedData04 を作成し、次に、非対称キー PrimeKey を使用して署名したレコードをテーブルに挿入します。このキーは最初にパスワード 'pGFD4bb925DGvbd2439587y' で暗号化解除されます。

-- Create a table in which to store the data
CREATE TABLE [SignedData04]( Description nvarchar(max), Data nvarchar(max), DataSignature varbinary(8000) );
GO
-- Store data together with its signature
DECLARE @clear_text_data nvarchar(max);
set @clear_text_data = N'Important numbers 2, 3, 5, 7, 11, 13, 17, 
      19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79,
      83, 89, 97';
INSERT INTO [SignedData04] 
    VALUES( N'data encrypted by asymmetric key ''PrimeKey''',
    @clear_text_data, SignByAsymKey( AsymKey_Id( 'PrimeKey' ),
    @clear_text_data, N'pGFD4bb925DGvbd2439587y' ));
GO