MariaDB 给指定列值自动加密(持久数据加触发器)

文章目录

参考链接:

一篇非常好的讲解触发器的文章:示例、原理MySQL/MariaDB触发器

用触发器自动加密的应用文章mysql触发器-插入更新数据时字段值自动加密

delimiter的作用可以参考这里

代码

插入时,自动加密

sql 复制代码
-- 删除原先的触发器
DROP TRIGGER IF EXISTS 【触发器名,如t_insert_tbStu_oValue】; 	
-- 创建触发器
DELIMITER $$
CREATE TRIGGER 【触发器名,如t_insert_tbStu_oValue】 		
BEFORE INSERT ON 【表名】FOR EACH ROW -- 触发在这张表新增数据前
BEGIN  -- 要执行的sql list 开始
        IF new.【列名】 IS NOT NULL THEN
        SET new.【列名】 = to_base64(aes_encrypt(new.【列名】,"【你的密码】"));
        END IF;
END;
END; $$
DELIMITER ;

在MySQL/MariaDB中,

new 表 : 表示向表中插入新记录之前,新记录保存在new表中,即inserted表。

对应的,old表 表示删除目标记录之后将删除的记录保存在old表中,即deleted表。

update操作 基本可以认为是先delete再insert的行为,所以也会触发这两张表。

sql中可以引用这两张表中的列,例如引用old.col_name

另外:

DELIMITER 默认是;,但是可以指定成其他的,例如由$$字代替,这样,在指定时DELIMITER $$和再次出现表示语句结束的$$之间,就可以出现;(不作为分隔符,但是可以作为嵌套的语句的结束),并且作为整体的一部分来执行。

更新时,自动加密

使用update语句时,插入的值,会是加密后的数据。

sql 复制代码
DROP TRIGGER IF EXISTS 【触发器名,如t_update_tbStu_oValue】;
DELIMITER $$
CREATE TRIGGER 【触发器名,如t_update_tbStu_oValue】 	-- 创建触发器
BEFORE UPDATE ON 【表名】 FOR EACH ROW
BEGIN  -- 要执行的sql list 开始
        IF new.【列名】IS NOT NULL   THEN
        SET new.【列名】= TO_BASE64 (AES_ENCRYPT (new.【列名】,'【你的密码】'));
        END IF;
END;$$
DELIMITER ;

查看触发器

sql 复制代码
SHOW TRIGGERS;

数据操作示例

update数据
bash 复制代码
USE 【数据库名】;
SHOW TRIGGERS;
SELECT * FROM 【表名】LIMIT 10;
update 【表名】 SET oValue = 2 
	WHERE oName = "【筛选条件】";
SELECT * FROM 【表名】 LIMIT 10;
取出

直接取

sql 复制代码
SELECT oValue 
	FROM 【表名】
	WHERE oName = "【筛选条件】";
解密取
sql 复制代码
SELECT AES_DECRYPT(FROM_BASE64(oValue), '【你的密码】') 
	FROM 
	(SELECT oValue
	FROM 【表名】
	WHERE oName = "【筛选条件】") 
	as oValue;

注意

一次尝试,看加密后数据长度

sql 复制代码
-- 判断数据长度 
-- 源数据 120位
SELECT TO_BASE64(AES_ENCRYPT('yML93Cb2ZYnwrRUSyc+5ETicNwfbpVRKe03XGlSXHOKvA3lMWnHCof8wFnsaYwVWMvBl6YssUbQt/MngjFUbSW709eFr1nsOcSSZy9wn61nDvZN5qm1mypDN','【我的密码】'));

-- 结果 172位
'oGxxBBxQVjN2CoVxiZ08dX3BLb9xCEFwQqEk4eZJjwVtuGHKYjyfsy+fBp66euJMwts8Fzv0rnQSisrdCopKS1HSx5YUmRUsEsZubPp7BepIqjwVEtU9uCCJXetFlhIcjyapt+clGVZx4gici4B6jPsKP2DB3C1nYq9FsJBS1Ts='
相关推荐
啊吧怪不啊吧30 分钟前
极致性能的服务器Redis之String类型及相关指令介绍
网络·数据库·redis·分布式·mybatis
zihan032131 分钟前
Redis Windows版本默认配置文件,Redis配置不生效解决方案
数据库·redis·缓存
Hgfdsaqwr1 小时前
实战:用Python开发一个简单的区块链
jvm·数据库·python
砚边数影1 小时前
InfluxDB迁移替换实战:金仓时序数据库如何提高写入性能
数据库·性能优化·时序数据库·kingbase·kingbasees·金仓数据库
eWidget8 小时前
InfluxDB迁移至金仓数据库的同城容灾实践:性能显著提升、运维效率优化,某能源企业实现RPO_5秒的高可靠时序数据管理
运维·数据库·能源·时序数据库·kingbase·kingbasees·金仓数据库
小句8 小时前
MySQL慢查询日志详细使用指南
数据库·mysql·adb
老邓计算机毕设9 小时前
SSM医疗资源普查6qxol(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb开发·医疗资源管理
dyyx1119 小时前
如何从Python初学者进阶为专家?
jvm·数据库·python
码农水水9 小时前
中国邮政Java面试被问:容器镜像的多阶段构建和优化
java·linux·开发语言·数据库·mysql·面试·php
曹牧9 小时前
Oracle:NULL
数据库·oracle