目录

  • 前言
  • 一、数据脱敏解释
  • 二、数据脱敏实现
    • 1.CONCAT()、LEFT() 和 RIGHT() 字符串函数组合使用
    • 2.INSERT()
  • 总结

前言

在日常开发需求中会经常遇到数据脱敏处理,比如身份证号、手机号,需要使用*进行部分替换显示。这样能使敏感隐私信息在一定程度上得到保护。那么什么是数据脱敏呢?


一、数据脱敏解释

这里我们直接引用360百科解释。

360百科解释:
数据脱敏是指对某些敏感信息通过脱敏规则进行数据的变形,实现敏感隐私数据的可靠保护。在涉及客户安全数据或者一些商业性敏感数据的情况下,在不违反系统规则条件下,对真实数据进行改造并提供测试使用,如身份证号、手机号、卡号、客户号等个人信息都需要进行数据脱敏。

二、数据脱敏实现

数据脱敏实现可以从数据库查数据的时候进行处理,可以在查出数据后进行处理。在这里记录了 MySQL 数据库查询时处理,通过使用 MySQL 字符串函数实现。
首先执行 SQL 语句:

SELECT IdentityCardNo FROM c_inhabitantinfo;

结果得到了原样的两条身份证号码信息。

接下来我们看 MySQL 实现数据脱敏。

1.CONCAT()、LEFT() 和 RIGHT() 字符串函数组合使用

  • CONCAT(str1, str2, …):返回结果为连接参数产生的字符串
  • LEFT(str, len):返回从字符串 str 开始的 len 最左字符
  • RIGHT(str, len):从字符串 str 开始,返回最右 len 字符

执行 SQL 语句:

SELECT CONCAT(LEFT(IdentityCardNo,3), '****' ,RIGHT(IdentityCardNo,4)) AS 身份证号
FROM c_inhabitantinfo;

我们看到如下图的结果,也就是实现了数据脱敏。

2.INSERT()

  • INSERT(str, pos, len, newstr):返回字符串 str,其子字符串起始于 pos 位置和长期被字符串 newstr 取代的 len 字符

执行 SQL 语句:

SELECT INSERT(IdentityCardNo, 4, 11, '****') AS 身份证号 FROM c_inhabitantinfo;

我们看到如下图的结果,也就是实现了数据脱敏。


总结

身份证号、手机号等敏感数据脱敏已经是开发中必实现的功能之一,本文主要介绍了使用 MySQL 的 SQL 语法实现数据脱敏。

MySQL 对身份证号、手机号等敏感数据脱敏相关推荐

  1. mysql对身份证号进行隐藏、脱敏处理

    一.客户要求身份证号取前3和后3.中间用*,于是有: CONCAT( LEFT(SAFE_DIRECTOR_ID_CARD,3), '************' , RIGHT(SAFE_DIRECT ...

  2. 前端利用正则对手机号码,身份证号,姓名进行脱敏处理

    前端利用正则对手机号码,身份证号,姓名进行脱敏处理 一.脱敏规则 手机号码:第4到第7位用掩码替换 身份证号:第7-14位用掩码替换 姓名:保留姓,名(无论一位或两位)统一用一个*替换 二.脱敏方法 ...

  3. mysql根据身份证号查 性别、年龄以及出生日期

    mysql根据身份证号查性别.年龄以及出生日期 博客里面还有对应的java工具类:芜湖,起飞 这个身份证号也就只针对大陆身份证号 SELECT p.id,-- 这是根据身份证号求年龄 (YEAR(NO ...

  4. 网易有道IP,身份证号, 手机号归属地API查询接口

    网易有道IP,身份证号, 手机号归属地API查询接口 http://www.youdao.com/smartresult-xml/search.s?type=ip&q=ip地址 GET后返回X ...

  5. MySQL对身份证号、手机号等敏感信息用****加密

    目录 身份证 手机 邮箱 对表中敏感信息身份证号.手机号.邮箱进行***加密处理 身份证 UPDATE student set SFZ=REPLACE(SFZ,SUBSTRING(SFZ,11,8), ...

  6. java身份证号/手机号隐藏中间几位

    java代码身份证/手机隐藏中间几位 手机号 --保留前3,后4位: String phone = "13525658745"; System.out.println(phone. ...

  7. mysql 用身份证号判断年龄

    要使用 MySQL 计算出一个人的年龄根据其身份证号,您需要以下步骤: 在 MySQL 中存储该人的身份证号和出生日期. 使用 MySQL 的函数 YEAR() 和 DATEDIFF() 计算出生日期 ...

  8. 姓名,身份证号,关键信息脱敏

    <template><a-table id="tabledata" ref="table" size="middle" b ...

  9. MySql 根据身份证号来判别所属省份年龄及性别

    一.背景: 新项目要从别的系统迁移用户表信息,老的用户表里的数据有很多不规范的数据,需要通过表里的身份证号获取用户的省份.年龄.性别. 二.获取方式: 1.通过身份证号获取省份. SELECT CAS ...

最新文章

  1. Data source rejected establishment of connection, message from server: Too many connections解决办法...
  2. 不再为Apache进程淤积、耗尽内存而困扰[转载]
  3. 口语学习Day8:今天聊聊微信有关的英语总结!
  4. Log4Net 使用 FileAppender (log4net 1.2.10.0)
  5. 【AI白身境】学深度学习你不得不知的爬虫基础​​​​​​​
  6. Windows Mobile Topics at TechEd 2008
  7. 「原创」从马云、马化腾、李彦宏的对话,看出三人智慧差在哪里?
  8. javascript入门_JavaScript入门手册(2020版)
  9. Android 切换卡(TabWidget)
  10. 深入理解JVM-java内存区域与内存溢出异常
  11. 数字图像处理-基本知识总结
  12. 高斯求积分公式matlab,matlab高斯积分公式
  13. 5.3 数值分析: 差商的定义及性质
  14. 3D-GIS地理信息系统的研究现状和发展趋势
  15. 华为CE6881端口联动限制
  16. app被Rejected 的各种原因翻译
  17. 使用ldapmodify修改条目
  18. python猜单词游戏_Python小程序之猜单词游戏
  19. ROS2学习tf2坐标变换
  20. 怪物猎人服务器维护时间,怪物猎人OL

热门文章

  1. Ehcache配置详解
  2. 国内、国际手机号正则表达式
  3. 字符串转int数据类型的三种方式
  4. win10打印机共享
  5. 蜂蜜糖分高健康吗?蜂蜜含糖量高不高?
  6. 锂电池基础知识01——锂聚合物电池燃烧实验
  7. 【天津大学】成立一所国家研究院
  8. 使用Angular8和百度地图api开发《旅游清单》
  9. ie浏览器提示缺少标识符_IE11和神秘的缺少浏览器模式
  10. SQLSERVER查看数据库日志方法和语句示例,已亲测。