dopnpoh056622 2016-06-10 19:51
浏览 102
已采纳

在sql查询中满足条件时,使用前三个字符的***显示字段的结果

I have a table that look like this :

Username   |   Status
aaa        |   Pending
bbbbbbb    |   Pending
cccc       |   Cancelled
dddddddd   |   Cancelled
eeeeee     |   Approved
ffffff     |   Approved

the result that I'd like to show at the end is like this :

Status    | Username
Pending   | ***aaa, ***bbbb
Cancelled | ***cccc, ***ddddd 
Approved  | ***eee, ***fff

I've tried to do this select query

SELECT distinct status,CASE WHEN LENGTH(username) >=6 THEN GROUP_CONCAT(replace(username, left( username, 3 ) , '***') SEPARATOR ', ') ELSE GROUP_CONCAT('***',username SEPARATOR ', ') END AS Username FROM table group by status

However, the result of bbbbbbb from my query won't work because there is 3 characters username at first row. so, the result become like this :

Status    | Username
Pending   | ***aaa, ***bbbbbbb       // wrong (it should be ***aaa , ***bbbb)
Cancelled | ***cccc, ***ddddd // true
Approved  | ***eee, ***fff   // true

How do I perform the query to show the result that I expected?. thank you before

  • 写回答

1条回答 默认 最新

  • down2323 2016-06-10 22:14
    关注

    As I understand, you need to move CASE inside GROUP_CONCAT. Something like this:

    SELECT DISTINCT status,
      GROUP_CONCAT(
        CASE
          WHEN LENGTH(username) >= 6 THEN REPLACE(username, LEFT(username, 3), '***')
          ELSE CONCAT('***', username)
        END SEPARATOR ', '
      )AS Username
    FROM table
    GROUP BY status
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部