我想创建一个检查加密的查询,并输出随机给定的数据库表中的所有列(如果它们是加密的)。 所以我希望输出看起来像这样
Column Name | Encryption Key Name | Encryption Type | Algorithm Used
Baby Power Key name for bp Randomized AEAD_AES_256_CBC_HMAC_SHA_256
Diaper Key name for Diaper Deterministic AEAD_AES_256_CBC_HMAC_SHA_256
答案 0 :(得分:1)
您可以使用以下查询:
SELECT
t.name AS TableName,
c.name AS ColumnName,
k.name AS KeyName,
c.encryption_type_desc,
c.encryption_algorithm_name
FROM sys.columns c
INNER JOIN sys.column_encryption_keys k ON c.column_encryption_key_id = k.column_encryption_key_id
INNER JOIN sys.tables t ON c.object_id = t.object_id
WHERE encryption_type IS NOT NULL
这将返回当前数据库中的所有加密列。如果您只想要特定的表格,请在t.name
上添加带过滤条件的条件。
通常,如果要查找有关不同数据库对象的信息,sys
模式下的系统视图是正确的位置。