duck_younian 2019-11-22 18:10 采纳率: 0%
浏览 220

db2数据库加密,怎样实现?

例如已存在
表 table User,包含字段 id, name, tel;
表 table Emp,包含字段 id, userId, address;
这两张表都已存在上千万数据,现在要对User表和Emp表的tel 和 address字段进行加密,如何处理?

知道能重建表,对应的字段设置为for bit data数据类型,然后将旧表数据转移到新表;但是这种效果不太理想。
因为程序那里不可能修改sql语句,给对应insert、update语句中对应的字段添加encrypt;select语句添加decrypt_char函数,这样需修改的地方,耗费的时间太长久。

  • 写回答

1条回答 默认 最新

  • 憧憬blog 2023-03-15 04:51
    关注

    对于这个问题,可以考虑使用数据库的加密功能来进行操作。具体来说,可以使用db2数据库提供的Transparent Data Encryption (TDE) 来加密数据。

    使用TDE,需要完成以下步骤:

    1. 创建一个称为“密钥库”的容器
    2. 生成一个加密密钥
    3. 将密钥存储在密钥库中
    4. 使用加密密钥加密表中的敏感字段
    5. 重启DB2实例

    在执行以上步骤后,所有在加密表中查询时,DB2将自动解密数据。

    需要注意的是,使用TDE之前需要对数据库进行备份,以便在出现问题时进行恢复。

    总的来说,使用TDE可以有效地保护敏感数据,同时不需要修改程序中sql语句,具有较好的效果和安全性。

    评论

报告相同问题?

悬赏问题

  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3