数据加密-mysql

想要实现数据加密可以在mysql数据库表实现数据加密,来确保数据安全。下面就是加密算法AES_ENCRYPT,其他加密算法类似。

1 创建一张临时表test_table

sql 复制代码
CREATE TABLE `test_table` (
  `name` varchar(20) DEFAULT NULL,
  `id` blob
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

2 在里面插入2条数据

sql 复制代码
insert into  test_table VALUES('张三',100);
insert into  test_table VALUES('李四',200);

3 查看数据

sql 复制代码
select * from test_table;

4 对数据加密

使用这个AES_ENCRYPT加密规则对数据表name,id进行加密

AES_ENCRYPT(str,key_str) -- str 用于加密的字符串,key_str 密钥字符串

sql 复制代码
create table test_table3 as 
select name,id,AES_ENCRYPT(name,'MySQL') as name_aes,AES_ENCRYPT(name,123) as name_123,AES_ENCRYPT(id,123) name_id from test_table;

5 加密后的数据

很明显

sql 复制代码
select * from test_table3;

6 对加密数据进行解密

AES_DECRYPT(str,key_str) -- str 用于解密的字符串,key_str 密钥字符串

sql 复制代码
select 
	AES_DECRYPT(name_aes,'MySQL')
	,AES_DECRYPT(name_123,123)
	,AES_DECRYPT(name_id,123)
	,AES_DECRYPT(name_id,124) 
from test_table3;

很明显,在前三个字段均是正确的密钥,在第四个字段我特意把密钥写成124,查出的数据是NULL,在我们密钥写错时数据是空的。也可以利用这一点来验证我们的数据是否解密成功。

在实际应用中还有很多加密算法可以使用,具体要看需求者对自己的数据安全是如何考量的。个人觉得一般的加密算法足够使用了。

相关推荐
程序员岳焱1 小时前
Java 与 MySQL 性能优化:MySQL全文检索查询优化实践
后端·mysql·性能优化
喜欢敲代码的程序员2 小时前
SpringBoot+Mybatis+MySQL+Vue+ElementUI前后端分离版:项目搭建(一)
spring boot·mysql·elementui·vue·mybatis
AI、少年郎2 小时前
Oracle 进阶语法实战:从多维分析到数据清洗的深度应用(第四课)
数据库·oracle
赤橙红的黄2 小时前
自定义线程池-实现任务0丢失的处理策略
数据库·spring
钢铁男儿2 小时前
C# 委托(调用带引用参数的委托)
java·mysql·c#
叁沐2 小时前
MySQL 02 日志系统:一条SQL更新语句是如何执行的?
mysql
DataGear2 小时前
如何在DataGear 5.4.1 中快速制作SQL服务端分页的数据表格看板
javascript·数据库·sql·信息可视化·数据分析·echarts·数据可视化
weixin_438335402 小时前
分布式锁实现方式:基于Redis的分布式锁实现(Spring Boot + Redis)
数据库·redis·分布式
RunsenLIu2 小时前
基于Vue.js + Node.js + MySQL实现的图书销售管理系统
vue.js·mysql·node.js
码不停蹄的玄黓3 小时前
MySQL Undo Log 深度解析:事务回滚与MVCC的核心功臣
数据库·mysql·undo log·回滚日志