达梦(DM)数据库存储加密

达梦DM数据库存储加密

这里主要讲述DM数据库存储加密中比较常用也比较容易理解的非透明加密相关内容。

非透明加密

引用官方的话说:DM 对非透明加密的支持是通过对用户提供加解密接口实现的。用户在使用非透明加密时,需要提供密钥并调用加解密接口。采用非透明加密可以保证个人私密数据不被包括 DBA 在内的其他人获取。

非透明加密通过用户调用存储加密函数来进行,DM 提供了一系列的存储加密函数,还提供了一个数据加密包 DBMS_OBFUSCATION_TOOLKIT。

简单的说:就是DM数据库提供了存储加密函数,用户调用存储加密函数对指定的数据进行加解密操作。

CFALGORITHMSENCRYPT

对指定类型的明文进行加密,并返回密文,密文数据类型和 SRC 类型相同,语法格式

sql 复制代码
CFALGORITHMSENCRYPT(
    SRC VARCHAR/TEXT/CLOB,
    ALGORITHM INT,
    KEY VARCHAR
)

参数说明:

SRC 需要被加密明文的类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

获取当前DM数据库支持的加密算法

sql 复制代码
SELECT * FROM V$CIPHERS;

执行加密操作

sql 复制代码
select CFALGORITHMSENCRYPT('111111',514,'secret key');

CFALGORITHMSDECRYPT

对密文进行解密,并得到加密前的相同数据类型的明文,语法格式

sql 复制代码
CFALGORITHMSDECRYPT(

    SRC VARCHAR/TEXT/CLOB,

    ALGORITHM INT,

    KEY VARCHAR

)

参数说明:

SRC 需要被解密密文的数据类型

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

执行解密操作

sql 复制代码
select CFALGORITHMSDECRYPT('9FF46AA8D86FB25ADED775837F400BB5FE',514,'secret key');

SF_ENCRYPT_BINARY

对 VARBINARY 类型明文进行加密,并返回密文,语法格式

sql 复制代码
SF_ENCRYPT_BINARY(

    SRC VARBINARY,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被加密的 VARBINARY 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

加密语句

sql 复制代码
select SF_ENCRYPT_BINARY(0x12345678EF,514,'secret key',NULL);

SF_DECRYPT_TO_BINARY

对密文进行解密,并得到加密前的 VARBINARY 类型明文,语法格式

sql 复制代码
SF_DECRYPT_TO_BINARY(

    SRC VARBINARY,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被解密的 VARBINARY 类型密文

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

解密语句

sql 复制代码
select SF_DECRYPT_TO_BINARY('0x78AAAC21D0A2875AB86DDF16D9E0C063',514,'secret key',NULL);

SF_ENCRYPT_CHAR

对 VARCHAR 类型明文进行加密,并返回密文,语法格式

sql 复制代码
SF_ENCRYPT_CHAR(

    SRC VARCHAR,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被加密的 CHAR/VARCHAR 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

加密语句

sql 复制代码
select SF_ENCRYPT_CHAR('111111',514,'secret key',NULL);

SF_DECRYPT_TO_CHAR

对密文进行解密,并得到加密前的 VARCHAR 类型明文,语法格式

sql 复制代码
SF_DECRYPT_TO_CHAR(

    SRC VARBINARY,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被解密的 VARBINARY 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

解密语句

sql 复制代码
select SF_DECRYPT_TO_CHAR('0x9FF46AA8D86FB25ADED775837F400BB5',514,'secret key',NULL);

SF_ENCRYPT_DATE

对 DATE 类型明文进行加密,并返回密文,语法格式

sql 复制代码
SF_ENCRYPT_DATE(

    SRC DATE,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被加密的 DATE 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

加密语句

sql 复制代码
select SF_ENCRYPT_DATE(cast('2023-11-11' AS DATE),514,'secret key',NULL);

SF_DECRYPT_TO_DATE

对密文进行解密,并得到加密前的 DATE 类型明文,语法格式

sql 复制代码
SF_DECRYPT_TO_DATE(

    SRC VARBINARY,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被解密的 VARBINARY 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

解密语句

sql 复制代码
select SF_DECRYPT_TO_DATE('0x67331E1603728F30CA76DC3B4C77A028',514,'secret key',NULL);

SF_ENCRYPT_DATETIME

对 DATETIME 类型明文进行加密,并返回密文,语法格式

sql 复制代码
SF_ENCRYPT_DATETIME(

    SRC DATETIME,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被加密的 DATETIME 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

加密语句

sql 复制代码
select SF_ENCRYPT_DATETIME(cast('2023-11-11 11:11:11' AS datetime),514,'secret key',NULL);

SF_DECRYPT_TO_DATETIME

对密文进行解密,并得到加密前的 DATETIME 类型明文,语法格式

sql 复制代码
SF_DECRYPT_TO_DATETIME(

    SRC VARBINARY,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被加密的 DATETIME 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

解密语句

sql 复制代码
select SF_DECRYPT_TO_DATETIME ('0xF46D6469B5958A4D04C96948F8F9428C',514,'secret key',NULL);

SF_ENCRYPT_DEC

对 DEC 类型明文进行加密,并返回密文,语法格式

sql 复制代码
SF_ENCRYPT_DEC(

    SRC DEC,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被加密的 DEC 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

加密语句

sql 复制代码
select SF_ENCRYPT_DEC(cast('3.1415900000' AS dec(15,8)),514,'secret key',NULL);

SF_DECRYPT_TO_DEC

对密文进行解密,并得到加密前的 DEC 类型明文,语法格式

sql 复制代码
SF_DECRYPT_TO_DEC(

    SRC VARBINARY,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被解密的 VARBINARY 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

解密语句

sql 复制代码
select SF_DECRYPT_TO_DEC ('0xE19597CBA4C0EAA4437454BB12041A49',514,'secret key',NULL);

SF_ENCRYPT_TIME

对 TIME 类型明文进行加密,并返回密文,语法格式

sql 复制代码
SF_ENCRYPT_TIME(

    SRC TIME,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCAHR

)

参数说明:

SRC 需要被加密的 TIME 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

加密语句

sql 复制代码
select SF_ENCRYPT_TIME(cast('11:11:11' AS time),514,'secret key',NULL);

SF_DECRYPT_TO_TIME

对密文进行解密,并得到加密前的 TIME 类型明文,语法格式

sql 复制代码
SF_DECRYPT_TO_TIME(

    SRC VARBINARY,

    ALGORITHM INT,

    KEY VARCHAR,

    IV VARCHAR

)

参数说明:

SRC 需要被解密的 VARBINARY 类型数据

ALGORITHM 加密算法 ID,不可以为 NULL。加密算法对应的 ID 可通过查询 V$CIPHERS 得到

KEY 采用的密钥,不可以为 NULL

IV 采用的初始化矢量,可以为 NULL

解密语句

sql 复制代码
select SF_DECRYPT_TO_TIME ('0x8EEFEE4328CE85853D81179C8D17EA87',514,'secret key',NULL);

SF_GET_CIPHER_NAME

根据加密算法 ID,获取加密算法的名称

sql 复制代码
SF_GET_CIPHER_NAME(

  CIPHER_ID IN INT

)

参数说明:

CIPHER_ID 加密算法 ID

获取加密算法名称语句

sql 复制代码
select SF_GET_CIPHER_NAME(514);

到这里,关于DM数据库常用的加密函数,也就是半透明加密方式也就说完了。

相关推荐
大模型玩家七七6 分钟前
安全对齐不是消灭风险,而是重新分配风险
android·java·数据库·人工智能·深度学习·安全
李少兄6 分钟前
MySQL 中为时间字段设置默认当前时间
android·数据库·mysql
码海踏浪16 分钟前
从简单到专业在OceanBase中查看SQL是否走索引
数据库·sql·oceanbase
qinyia16 分钟前
**使用AI助手在智慧运维中快速定位并修复服务异常:以Nginx配置错误导致502错误为例**
linux·运维·服务器·数据库·mysql·nginx·自动化
熊文豪23 分钟前
关系数据库替换用金仓——Oracle兼容性深度解析
数据库·oracle·金仓数据库·电科金仓·kes
eWidget28 分钟前
面向Oracle生态的国产高兼容数据库解决方案
数据库·oracle·kingbase·数据库平替用金仓·金仓数据库
A懿轩A31 分钟前
【MySQL 数据库】MySQL 数据库核心概念详解:库、表、字段、主键与关系型模型一文读懂
数据库·mysql·oracle
盒马coding36 分钟前
postgreSQL中调整Checkpoint的重要性
数据库·mysql·postgresql
怣501 小时前
MySQL多表连接完全指南:内连接与外连接(零基础入门版)
数据库·mysql
爱吃山竹的大肚肚1 小时前
文件上传大小超过服务器限制
java·数据库·spring boot·mysql·spring