sql >> Databáze >  >> RDS >> Sqlserver

Šifrování databázových tabulek v SQL Server 2008

Zde máte různé možnosti.

  • Pro svá data můžete použít symetrické šifrování:

    CREATE TABLE sales (...)

Vytvořit symetrický klíč:

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

Šifrovat data:

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;

Dešifrovat data:

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;
  • Pro svá data můžete použít asymetrické šifrování
  • Můžete použít Transparentní šifrování dat pro šifrování všech databázových souborů:

Vytvořit hlavní klíč:

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

Vytvořit certifikát:

CREATE CERTIFICATE DEK_EncCert WITH SUBJECT = 'DEK Encryption Certificate'

Vytvořit DEK:

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

Zapnout šifrování:

ALTER DATABASE MySecretDB SET ENCRYPTION ON
  • Můžete použít BitLocker – úplné šifrování svazku


  1. Poddotazy a vícenásobné tabulky

  2. ORACLE SQL Spuštění TOTAL a daytotal pomocí funkce okna

  3. Entity Framework a Oracle:Nelze vložit VARCHAR2> 1 999 znaků

  4. 4 způsoby, jak získat definici pohledu pomocí Transact-SQL