Microsoft SQL Server 如何隐藏客户姓名、手机号或者身份证号中的部分信息


 

文章目录

        隐藏姓名中的姓氏或者名字
        隐藏手机号中间的四位数
        隐藏身份证号中间的四位数
        总结

姓名、手机号、身份证号以及银行卡号等属于个人敏感信息。为了保护信息安全,在前端界面显示时可能需要将这些信息中的部分内容进行隐藏,也就是显示为星号(*)。因此,本文给大家介绍一下如何在 Microsoft SQL Server 实现信息的隐藏。

隐藏姓名中的姓氏或者名字

以医院排队叫号系统为例,通常会隐藏患者的姓氏(两个字的姓名)或者名字中的倒数第二个字(三个字或更多字的姓名),例如“*备”或者“诸*亮”。对于 Microsoft SQL Server 而言,可以结合使用 CASE 表达式和字符串函数实现这一功能。例如(示例表):

SELECT TOP 5
       emp_name "隐藏之前",
       CASE len(emp_name)
         WHEN 2 THEN concat('*', right(emp_name, 1))
         ELSE concat(left(emp_name, len(emp_name)-2), '*', right(emp_name, 1))
       END "隐藏之后"
FROM employee
ORDER BY emp_id;

隐藏之前|隐藏之后|
-------|------|
刘备   |*备    |
关羽   |*羽    |
张飞   |*飞    |
诸葛亮 |诸*亮   |
黄忠   |*忠    |

其中,len(emp_name) 用于获取姓名中的字符个数;如果姓名只有两个字,只需要将一个星号和第 2 个字连接起来,right 函数用于返回第 2 个字;如果姓名包含三个或者更多字,将倒数第 2 个字用星号替代,left 函数用于返回字符串左侧的字符。

    📝除了使用 left 和 right 函数返回子串之外,也可以使用 substring 函数实现相同的功能。

实际上我们还可以进一步简化,直接使用上面的 ELSE 分支实现所有功能:

SELECT TOP 5
       emp_name "隐藏之前",
       concat(left(emp_name, len(emp_name)-2), '*', right(emp_name, 1)) "隐藏之后"
FROM employee
ORDER BY emp_id;

如果姓名只有两个字的话,concat 函数中的第一个参数实际上是空字符串。

另外,Microsoft SQL Server 还提供了一个 stuff( character_expression , start , length , replaceWith_expression ) 函数,用于在字符串 character_expression 的指定位置 start 之后使用子串 replaceWith_expression 替换随后的 length 个字符。

更多请见:http://www.mark-to-win.com/tutorial/51508.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值