Mysql之一对多查询,如何将多条记录合并成一条记录
来源:互联网 发布:金融数据库 免费 编辑:程序博客网 时间:2024/06/06 03:12
数据库环境:mysql5.6
需求描述(图1):
最终期望的结果(图2):
如上图所示,现有两张表cj_lottery_winning_record和cj_lottery_winning_user_info
两者的关系是一对多。
现在进行连接查询时,
SELECT
a.id winning_id,
a.awards_setting_id,
a.award_name,
a.award_type,
a.create_time,
a.awards_name,
a.get_status,
a.push_status,
b.key,
b.value honoree_info
FROM
cj_lottery_winning_record a
LEFT JOIN cj_lottery_record_user_info b
ON a.id = b.winning_id
WHERE activity_id=’100270’
ORDER BY a.create_time DESC LIMIT 0,10;
会得到图1所示的结果。
如果想得到图2所示的结果,只需将sql语句改成下面的即可:
SELECT
a.id winning_id,
a.awards_setting_id,
a.award_name,
a.award_type,
a.create_time,
a.awards_name,
a.get_status,
a.push_status,
b.info
FROM
cj_lottery_winning_record a
LEFT JOIN
(SELECT
winning_id,
GROUP_CONCAT(
IF(
key
= ‘微信’,
CONCAT(‘微信:’, value
, ‘,’),
IF(
key
= ‘手机’,
CONCAT(‘手机:’, value
, ‘,’),
IF(
key
= ‘地址’,
CONCAT(‘地址:’, value
, ‘,’),
”
)
)
)
) AS info
FROM
cj_lottery_record_user_info
GROUP BY winning_id) b
ON a.id = b.winning_id
WHERE a.activity_id = ‘100270’
ORDER BY a.create_time DESC
LIMIT 0, 10 ;
- Mysql之一对多查询,如何将多条记录合并成一条记录
- mysql如何查询最近的一条记录
- [MySQL] MySQL将多条记录的某个字段合并成一条记录
- MySQL数据库将多条记录的单个字段合并成一条记录
- MYSQL#将多条无关的数据库记录合并成一条记录,并取值
- mysql 查询 记录最长的一条记录
- mysql多条记录判断相加减合并一条
- group_concat()函数总结(mysql数据库中将某个字段的多条记录合并成一条记录),比较实用
- 查询MYSQl数据表中的最后一条记录
- MySQL随机查询出一条记录
- 查询mysql数据库的最后一条记录
- mysql合并多条记录的单个字段去一条记录
- SQL Server 如何查询最后一条记录
- 把多条记录合并成一条的SQL语句
- 如何查询数据库中重复记录的一条记录
- MYSQL中如何获取最后一条记录?
- 利用数据库表转置将多条记录合并成一条记录
- mysql插入一条记录,删除一条记录
- 在Ubuntu Linux上面安装Android Studio遇到的各种小问题记录
- RCF—用于C++的进程间通讯(3)
- 【OpenCV入门教程之一】 安装OpenCV:OpenCV 3.0、OpenCV 2.4.8、OpenCV 2.4.9 +VS 开发环境配置
- GYM 100694 F.The Berland Championship(最大流-Dinic)
- 懂商业的技术合伙人(5):初创公司的2个核心任务,团队练兵和探索方向
- Mysql之一对多查询,如何将多条记录合并成一条记录
- tensorflow 风格迁移
- Oracle常用查看表结构命令
- C++——NOIP模拟题——farm
- shell脚本之函数(八)
- 工作流概念
- jQuery-gcxSpringside 插件使用文档
- RCF—用于C++的进程间通讯(4)
- Hadoop练习wordcout+多文件输出