子查询似乎不起作用

时间:2016-09-08 02:15:33

标签: mysql subquery

mysql查询:

`SELECT IFNULL(party.`user_id`, 0) as isparticipant, a.`id`, a.`created`,` `a.`lastreplied`,` 

a.`type`, b.`created_by`, b.`message`, c.`isread`


FROM `jos_social_conversations` AS `a` 

LEFT JOIN `jos_social_conversations_participants` as party on a.id = party.conversation_id 
and party.user_id = '602' 

INNER JOIN `jos_social_conversations_message` AS `b` ON 
`a`.`id` = `b`.`conversation_id` 

INNER JOIN `jos_social_conversations_message_maps` AS `c` 
ON `c`.`message_id` = `b`.`id` and c.`conversation_id` = b.`conversation_id`



INNER JOIN  
(select cm.`conversation_id`, max(cm.`message_id`) as `message_id` from 
`jos_social_conversations_message_maps` as cm 

inner join `jos_social_conversations_message` as bm
on cm.`message_id` = bm.`id` 

LEFT JOIN `jos_social_block_users` AS `bus` ON `bm`.`created_by` = `bus`.`user_id` 

AND `bus`.`target_id` = '602' 

WHERE `cm`.`user_id` = '602' AND(SELECT count(isread) AS newMsg 


FROM jos_social_conversations_message_maps as maps WHERE a.id = maps.conversation_id AND 
maps.isread = 0 AND maps.user_id = '602') AND `cm`.`state` = '1' and `bus`.`id` IS NULL
group by cm.`conversation_id`) as x ON c.`message_id` = x.`message_id`



LEFT JOIN `jos_social_block_users`
as bus  ON a.`created_by` = bus.`user_id`  AND bus.`target_id` = '602' 

WHERE `c`.`user_id` = '602'



AND bus.`id` IS NULL AND `c`.`state` = '1'  

这会产生如下错误:

  

1054 - 未知栏' a.id'在' where子句'

来自以上查询的

子查询如下:

AND(SELECT count(isread) AS newMsg  FROM jos_social_conversations_message_maps WHERE conversation_id = 3 AND isread = 0 AND user_id = '602')

当前输出: enter image description here

预期输出:

应该有另一个名为'newMsg'的列显示'isread'列的总计数,其中'0'列为每个ID的值。

1 个答案:

答案 0 :(得分:1)

这是我的格式化版本:

SELECT IFNULL(party.`user_id`, 0) as isparticipant, a.`id`, a.`created`, a.`lastreplied`, a.`type`, b.`created_by`, b.`message`, c.`isread`
FROM `jos_social_conversations` AS `a`
LEFT JOIN `jos_social_conversations_participants` as party on a.id = party.conversation_id and party.user_id = '602'
INNER JOIN `jos_social_conversations_message` AS `b` ON `a`.`id` = `b`.`conversation_id`
INNER JOIN `jos_social_conversations_message_maps` AS `c` ON `c`.`message_id` = `b`.`id` and c.`conversation_id` = b.`conversation_id`
INNER JOIN  (select cm.`conversation_id`, max(cm.`message_id`) as `message_id`
             from `jos_social_conversations_message_maps` as cm
             inner join `jos_social_conversations_message` as bm on cm.`message_id` = bm.`id`
             LEFT JOIN `jos_social_block_users` AS `bus` ON `bm`.`created_by` = `bus`.`user_id` AND `bus`.`target_id` = '602'
             WHERE `cm`.`user_id` = '602' AND(SELECT count(isread) AS newMsg 
                                              FROM jos_social_conversations_message_maps
                                              WHERE conversation_id = 3 AND isread = 0 AND user_id = '602'
                                             )
                                          AND `cm`.`state` = '1'
                                          and `bus`.`id` IS NULL
             group by cm.`conversation_id`
            ) as x ON c.`message_id` = x.`message_id`
LEFT JOIN `jos_social_block_users` as bus  ON a.`created_by` = bus.`user_id`  AND bus.`target_id` = '602'
WHERE `c`.`user_id` = '602'
  AND bus.`id` IS NULL AND `c`.`state` = '1'


您的子查询是WHERE子句的一部分,因此它不会返回另一列。也许你看起来像这样:

SELECT IFNULL(party.`user_id`, 0) as isparticipant, a.`id`, a.`created`, a.`lastreplied`, a.`type`, b.`created_by`, b.`message`, c.`isread`,
       (SELECT count(isread)
        FROM jos_social_conversations_message_maps
        WHERE conversation_id = 3 AND isread = 0 AND user_id = '602'
       ) AS newMsg 
FROM `jos_social_conversations` AS `a`
{remainder removed for brevity}