SignByAsymKey (Transact-SQL)
使用非對稱金鑰簽署純文字。
語法
SignByAsymKey( Asym_Key_ID , @plaintext [ , 'password' ] )
引數
Asym_Key_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