SIGNBYCERT (Transact-SQL)

适用于:SQL ServerAzure SQL 数据库Azure SQL 托管实例

使用证书对文本进行签名并返回签名。

Transact-SQL 语法约定

语法

SignByCert ( certificate_ID , @cleartext [ , 'password' ] )  

注意

若要查看 SQL Server 2014 (12.x) 及更早版本的 Transact-SQL 语法,请参阅早期版本文档

参数

certificate_ID
当前数据库中证书的 ID。 certificate_ID 是 int

@cleartext
类型为 nvarchar、char、varchar 或 nchar 的变量,其中包含要签名的数据

' password '
用来对证书私钥进行加密的密码。 password 的数据类型为 nvarchar(128)

返回类型

varbinary(最大大小为 8000 个字节)。

注解

需要对证书具有 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)
加密层次结构