我有一个Windows应用程序,在SQL Server 2008中使用数据库。

我不希望用户看到数据库表。

如何加密数据库中的表?

最佳答案

您在这里有不同的选择。

  • 您可以对数据使用对称加密:

    创建表销售(
    ...
    )

  • 创建对称 key :
    CREATE CERTIFICATE cert_sales WITH SUBJECT = N'Sales certificate',
    START_DATE = N'2009-01-01', EXPIRY_DATE = N'2018-12-31';
    
    CREATE SYMMETRIC KEY symkey_sales WITH ALGORITHM = AES_256
    ENCRYPTION BY CERTIFICATE cert_sales
    

    加密数据:
    TRUNCATE TABLE sales;
    OPEN SYMMETRIC KEY symkey_sales DECRYPTION BY CERTIFICATE cert_sales;
    INSERT INTO sales() SELECT a, ENCRYPTBYKEY(Key_Guid(N'symkey_sales'), B) FROM T2;
    CLOSE SYMMETRIC KEY symkey_sales;
    

    解密数据:
    OPEN SYMMETRIC KEY symkey_sales DECRYPTION BY CERTIFICATE cert_sales;
    SELECT a, CAST(DecryptByKey(B) as nvarchar(100)) FROM sales;
    CLOSE SYMMETRIC KEY symkey_sales;
    
  • 您可以对数据使用非对称加密
  • 您可以使用透明数据加密来加密所有数据库文件:

  • 创建主 key :
    USE master
    go
    CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'My$Strong$Password$123'
    

    创建证书:
    CREATE CERTIFICATE DEK_EncCert WITH SUBJECT = 'DEK Encryption Certificate'
    

    创建DEK:
    USE MySecretDB
    go
    CREATE DATABASE ENCRYPTION KEY WITH ALGORITHM = AES_256
    ENCRYPTION BY SERVER CERTIFICATE DEK_EncCert
    

    打开加密:
    ALTER DATABASE MySecretDB SET ENCRYPTION ON
    
  • 您可以使用BitLocker-完整的卷加密
  • 关于sql - 在SQL Server 2008中加密数据库表,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/8427001/

    10-11 17:25
    查看更多