Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

Chiffrement des tables de base de données dans SQL Server 2008

Vous avez différentes options ici.

  • Vous pouvez utiliser le chiffrement symétrique pour vos données :

    CREATE TABLE ventes (...)

Créer une clé symétrique :

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

Crypter les données :

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;

Déchiffrer les données :

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;
  • Vous pouvez utiliser le chiffrement asymétrique pour vos données
  • Vous pouvez utiliser le chiffrement transparent des données pour chiffrer tous les fichiers de la base de données :

Créer une clé principale :

USE master
go
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'My$Strong$Password$123'

Créer un certificat :

CREATE CERTIFICATE DEK_EncCert WITH SUBJECT = 'DEK Encryption Certificate'

Créer DEK :

USE MySecretDB
go
CREATE DATABASE ENCRYPTION KEY WITH ALGORITHM = AES_256
ENCRYPTION BY SERVER CERTIFICATE DEK_EncCert

Activez le chiffrement :

ALTER DATABASE MySecretDB SET ENCRYPTION ON
  • Vous pouvez utiliser BitLocker - chiffrement complet du volume