一个SQL问题

现实生活中,每个人都有可能存在多个电话号码,可能是移动,可能是联通,或者电信。

现在一家公司的一个user表里,有id、name、phone

但是phone保存的电话号码,并没有把移动、联通、电信等电话号码分开

出现问题:一个用户可能多次出现在这个user表里,例如:

        id  name  phone

        1    小明    123

        2    小明    456

        3    小明    789

公司需求:要求你用SQL语句查出拥有多个电话的人名

具体要求:

1.只有一个电话号码的人名,我不要
2.我要有多个电话号码的人名
3.sql展示为   name phone phone phone

              例: 小明    123      456      789


答案:

SELECT name,GROUP_CONCAT(phone)

FROM user
WHERE
NAME IN (
SELECT
name
FROM
user
GROUP BY
name
HAVING
COUNT(name) > 1
)
GROUP BY

name;


新问题:如何优化这条SQL语句(待续)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值