Есть ли лучший способ написать запрос, который я написал - PullRequest
0 голосов
/ 08 сентября 2018

У меня есть следующий запрос, который дает мне общее состояние проекта. Мне было интересно, есть ли лучший способ написать тот же запрос.

пример схемы для таблицы:

CREATE TABLE `test_status`
(
      `test_id` int
(11) NOT NULL,
      `group_id` int
(11) NOT NULL,
      `sub_test_id` int
(11) NOT NULL,
      `project_id` int
(11) NOT NULL,
      `collection_status` varchar
(20) DEFAULT NULL,
      `labeling_status` varchar
(20) DEFAULT NULL,
      `upload_status` varchar
(20) DEFAULT NULL,
      `upload_date` date DEFAULT NULL,
      `disk_number` int
(11) DEFAULT NULL,
      `subject_id` varchar
(10) DEFAULT NULL,
      `collection_id` varchar
(25) DEFAULT NULL,
      `assigned_to` int
(11) DEFAULT NULL,
      `assigned_on` date DEFAULT NULL,
      `turned_in_date` date DEFAULT NULL,
      PRIMARY KEY
(`test_id`,`group_id`,`sub_test_id`,`project_id`));

Мой запрос:

select
    (select count(*)
    from test_status
    where project_id = 7 and collection_status = 'COLLECTED') as collected,
    (select count(*)
    from test_status
    where project_id = 7 and collection_status = 'SCHEDULED') as scheduled,
    (select count(*)
    from test_status
    where project_id = 7 and collection_status = 'CORRUPTED') as corrupted,
    (select count(*)
    from test_status
    where project_id = 7 and collection_status is NULL) as 'not collected',
    (select count(*)
    from test_status
    where project_id = 7 and ((labeling_status = 'GOOD' and (upload_status != 'UPLOADED' or upload_status != 'QUEUED')) or (labeling_status = 'Labeled'))) as 'Labeled',
    (select count(*)
    from test_status
    where project_id = 7 and (labeling_status = 'RAW') or (labeling_status = 'ASSIGNED') ) as 'to be labeled',
    (select count(*)
    from test_status
    where project_id = 7 and labeling_status = 'RE-LABEL') as 'Re-label',
    (select count(*)
    from test_status
    where project_id = 7 and (upload_status = 'UPLOADED' or upload_status = 'QUEUED')) as 'Uploaded',
    (select count(*)
    from test_status
    where project_id = 7 and labeling_status = 'GOOD' and upload_status is null) as 'ready to be uploaded';

1 Ответ

0 голосов
/ 08 сентября 2018

Вы можете попытаться использовать Функция агрегирования условий будет лучше.

пусть условие в CASE WHEN

SELECT 
    COUNT(CASE WHEN collection_status = 'COLLECTED' THEN 1 END),
    COUNT(CASE WHEN collection_status = 'SCHEDULED' THEN 1 END),
    COUNT(CASE WHEN collection_status = 'CORRUPTED' THEN 1 END),
    COUNT(CASE WHEN collection_status is NULL THEN 1 END),
    COUNT(CASE WHEN  ((labeling_status = 'GOOD' and (upload_status != 'UPLOADED' or upload_status != 'QUEUED')) or (labeling_status = 'Labeled'))THEN 1 END),
    COUNT(CASE WHEN (labeling_status = 'RAW') or (labeling_status = 'ASSIGNED') THEN 1 END),
    COUNT(CASE WHEN labeling_status = 'RE-LABEL' THEN 1 END),
    COUNT(CASE WHEN (upload_status = 'UPLOADED' or upload_status = 'QUEUED') THEN 1 END),
    COUNT(CASE WHEN labeling_status = 'GOOD' and upload_status is null THEN 1 END)
FROM test_status
WHERE project_id = 7

Или вы можете попробовать более простой способ: SUM с bool (0 или 1) до count

SELECT 
    SUM(collection_status = 'COLLECTED'),
    SUM(collection_status = 'SCHEDULED'),
    SUM(collection_status = 'CORRUPTED' ),
    SUM(collection_status is NULL ),
    SUM(((labeling_status = 'GOOD' and (upload_status != 'UPLOADED' or upload_status != 'QUEUED')) or (labeling_status = 'Labeled'))),
    SUM((labeling_status = 'RAW') or (labeling_status = 'ASSIGNED') ),
    SUM(labeling_status = 'RE-LABEL' ),
    SUM((upload_status = 'UPLOADED' or upload_status = 'QUEUED')),
    SUM(labeling_status = 'GOOD' and upload_status is null )
FROM test_status
WHERE project_id = 7
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...