野花一片 2017-01-05 02:08 采纳率: 33.3%
浏览 2475
已采纳

sql 查询将多个值合到一起

如有如下几条数据

中国 北京
中国 上海
中国 深圳
美国 XX
美国 YY

我想查询出来的结果为 两个字段 如下
中国 北京,上海,深圳
美国 XX,YY

这个可以实现吗

  • 写回答

6条回答 默认 最新

  • huhedong1182738042 2017-01-05 02:32
    关注

    CREATE DATABASE test;

    CREATE TABLE city(
    Id INT,
    pname VARCHAR(50),
    name VARCHAR(50)
    );

    USE test;

    INSERT INTO common.city (Id, pname, name)
    VALUES (1, '中国','北京');
    INSERT INTO common.city (Id, pname, name)
    VALUES (2, '中国','上海');

    INSERT INTO common.city (Id, pname, name)
    VALUES (3, '美国','XX');

    INSERT INTO common.city (Id, pname, name)
    VALUES (4, '美国','YY');

    SELECT pname,GROUP_CONCAT(name) AS name FROM city GROUP BY pname

    以上为mysql,如果是其他数据库,使用的函数不一样而已。orcale中使用wmsys.wm_concat,根据数据库类型不一样,函数不一样

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 slam rangenet++配置
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊