Mysql之一对多查询,如何将多条记录合并成一条记录
2017-03-25 14:39
417 查看
数据库环境: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(
CONCAT(‘微信:’,
IF(
CONCAT(‘手机:’,
IF(
CONCAT(‘地址:’,
”
)
)
)
) 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 ;
需求描述(图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查询最后几条、生成一条包含多条记录、插入语句、差值查询
- mysql合并多条记录的单个字段去一条记录编辑
- mysql 查询邻近的两条记录并合并成一条
- mysql中如何查询表的第一条和最后一条记录
- mysql中如何用一条sql语句删除多条记录及Shell下执行mysql语句和查询统计
- 使用distinct在mysql中查询多条不重复记录值的解决办法
- 用distinct在MySQL中查询多条不重复记录值
- 如何查询数据库中重复记录的一条记录
- 查询MYSQl数据表中的最后一条记录
- MYSQL中如何获取最后一条记录?
- 使用distinct在mysql中查询多条不重复记录值的解决办法
- 使用distinct在mysql中查询多条不重复记录值的解决办法
- 当有多条记录时,如何查询其中的一条的一个字段,并赋值给一个变量