Возвращать результаты и включать подведение итогов по переменным - PullRequest
0 голосов
/ 04 июня 2019

Я хотел бы обобщить данные DISTINCT, возвращаемые переменной id_module, а также отобразить id_content и заголовок.

Я пытался использовать array_sum, array_count и for_each ... Я изо всех сил пытаюсьпонять, как правильно это настроить.Я получил часть этого для работы и ищу направление, как получить остальные данные для отображения.

Вот пример массива JSON, который я могу получить, когда я выполняю следующий запрос:

 select DISTINCT id_module, id_cr, title from content WHERE (id_module = '003' OR id_module = '005')  
 UNION ALL
 SELECT DISTINCT id_module, id_cr, title FROM content_users WHERE (id_module = '003' OR id_module = '005') and id_user='999'

 Array
    (
         [content] => Array
             (
                 [0] => Array
                     (
                         [id_content] => 49620
                         [title] => Asthma: The Basics—Part 1
                         [id_module] => 001
                     )
                 [1] => Array
                     (
                         [id_content] => 49633
                         [title] => Asthma: The Basics—Part 2
                         [id_module] => 001
                     )
                 [2] => Array
                     (
                         [id_content] => 48469
                         [title] => Autism Spectrum Disorder
                         [id_module] => 002
                     )
               )
       )

Это запрос, который я использую для возврата суммированных результатов (у id_module могут быть дубликаты, поэтому мне нужны только модули DISTINCT, чтобы счетчик был верным).Этот запрос работает нормально и возвращает то, что я ожидаю:

select id_module, count(id_module) as total_module from 
    (
    select DISTINCT id_module, id_cr, title from content WHERE (id_module = '003' OR id_module = '005')  
    UNION ALL
    SELECT DISTINCT id_module, id_cr, title FROM content_users WHERE (id_module = '003' OR id_module = '005') and id_user='999'
)
as T GROUP BY id_module ORDER BY id_module

Возвращенные результаты:

id_module     total_module
  001              2
  002              1

Мне также нужно выполнить объединение обоих результатов обоих запросов... id_content и заголовок возвращены со сводкой ... что-то вроде этого, но мне не удалось написать запрос, который будет возвращаться в следующем формате:

id_module     total_module     id_content     title
  001              2              49620       Asthma: The Basics—Part 1
  001              2              49633       Asthma: The Basics—Part 2     
  002              1              48469       Autism Spectrum Disorder

Есть ли способ выполнитьэтот?Я благодарен за любой совет или направление - спасибо!

1 Ответ

1 голос
/ 04 июня 2019

Соедините два запроса в столбце id_module.

SELECT t1.id_module, t2.total_module, t1.id_cr, t1.title
FROM (
    select DISTINCT id_module, id_cr, title from content WHERE id_module IN ('003', '005')  
    UNION ALL
    SELECT DISTINCT id_module, id_cr, title FROM content_users WHERE id_module IN ('003', '005') and id_user='999'
) AS t1 
JOIN (
    SELECT id_module, COUNT(*) AS total_module
    FROM (
        select DISTINCT id_module, id_cr, title from content WHERE id_module IN ('003', '005')  
        UNION ALL
        SELECT DISTINCT id_module, id_cr, title FROM content_users WHERE id_module IN ('003', '005') and id_user='999'
    ) AS T
    GROUP BY id_module
) AS t2 ON t1.id_module = t2.id_module
ORDER BY t1.id_module

Также лучше использовать id_module IN (x, y, z, ...), а не id_module = x OR id_module = y OR id_module = z ....И используйте COUNT(*), если вам не нужно игнорировать нулевые значения в вашем счетчике.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...