0
我的应用程序利用关系表的表格,我用我的SQL连接视频与类别,演员和标签GROUP_CONCAT与DISTINCT。独特不消除空结果
我面临的问题是我会为演员输出拇指,但有时候演员还没有缩略图。在这种情况下,我在group_concat的行中产生的值与actor字段不一致,因为3个actor是唯一的,但是如果我有2个actor没有图像(null),那么我失去了锚点。
例如
SELECT
videos.id AS id,
videos.video_title AS video_title,
videos.video_views AS video_views,
videos.video_likes AS video_likes,
videos.video_dislikes AS video_dislikes,
videos.video_duration AS video_duration,
GROUP_CONCAT(DISTINCT a.actor_name SEPARATOR ';') AS actor_names,
GROUP_CONCAT(DISTINCT t.tag_name SEPARATOR ';') AS tag_names,
GROUP_CONCAT(DISTINCT c.category_name SEPARATOR ';') AS category_names,
GROUP_CONCAT(DISTINCT a.actor_thumb SEPARATOR ';') AS actor_thumbs
FROM videos
LEFT OUTER JOIN video_actors AS va ON va.video_id = videos.id
LEFT OUTER JOIN actor AS a ON a.actor_id = va.actor_id
LEFT OUTER JOIN video_tags AS vt ON vt.video_id = videos.id
LEFT OUTER JOIN tags AS t ON t.tag_id = vt.tag_id
LEFT OUTER JOIN video_categories AS vc ON vc.video_id = videos.id
LEFT OUTER JOIN categories AS c ON c.category_id = vc.category_id
WHERE videos.id = '23'
演员拇指场结果:
more fields.. |0;http://site.com/actor/59.jpg
但它应该是(3演员,2没有缩略图):
more fields.. |0;0;http://site.com/actor/59.jpg
为了保持对演员的名字值一致。
希望这有点清楚。
提前致谢! 尼克
编辑答案,actully我的第一个建议直接难道不具有鲜明的工作。 – barryhunter
感谢您的解决方案 – directory