SIGNBYASYMKEY (Transact-SQL)

適用於:SQL ServerAzure SQL DatabaseAzure SQL 受控執行個體

使用非對稱金鑰簽署純文字。

Transact-SQL 語法慣例

Syntax

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

注意

若要檢視 SQL Server 2014 (12.x) 和舊版的 Transact-SQL 語法,請參閱 舊版檔

引數

Asym_Key_ID
為目前資料庫中非對稱金鑰的識別碼。 Asym_Key_IDint

@plaintext
nvarcharcharvarcharnchar 類型的變數,其中包含要以非對稱金鑰簽署的資料。

password
為用來保護私密金鑰的密碼。 passwordnvarchar(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  

另請參閱

ASYMKEY_ID (Transact-SQL)
VERIFYSIGNEDBYASYMKEY (Transact-SQL)
CREATE ASYMMETRIC KEY (Transact-SQL)
ALTER ASYMMETRIC KEY (Transact-SQL)
DROP ASYMMETRIC KEY (Transact-SQL)
加密階層