MySql Count Query - PullRequest
       7

MySql Count Query

1 голос
/ 02 октября 2009

У меня есть запрос, над которым я работаю один раз. По сути, я пытаюсь найти все записи, в которых зарегистрировано более двух транзакций по одному идентификатору аккаунта в прошлом месяце. Я знаю, что это, вероятно, что-то легкое, мой разум просто отключается.

SELECT streaming_transactions.account_id,
   streaming_transactions_detail.transactions_description, 
   streaming_transactions_detail.transactions_detail_id, 
   streaming_transactions_detail.transactions_id, 
   streaming_transactions_detail.transactions_detail_amount, 
   streaming_transactions_detail.detail_type, 
   streaming_transactions_detail.products_id, 
   streaming_transactions_detail.products_levels_id, 
   streaming_transactions_detail.subscriptions_id, 
   streaming_transactions_detail.subscriptions_payment_options_id, 
   streaming_transactions_detail.modified
  FROM streaming_transactions_detail 
INNER JOIN streaming_transactions ON  streaming_transactions_detail.transactions_id = streaming_transactions.transactions_id
WHERE streaming_transactions.charged = 1 
  AND streaming_transactions.timestamp_inserted > '2009-09-01 00:00:00'
  AND streaming_transactions.account_id IN (
                 SELECT account_id
                       FROM streaming_transactions_detail
                      WHERE modified > '2009-09-01 00:00:00'
                        AND count(account_id) > 1)
AND streaming_transactions_detail.transactions_description LIKE '%Service Subscription%'
ORDER BY streaming_transactions.account_id DESC

1 Ответ

3 голосов
/ 02 октября 2009

Я думаю, ты почти у цели. Подзапрос для получения идентификаторов транзакций отключен, однако

         SELECT account_id
              FROM streaming_transactions_detail
              WHERE modified > '2009-09-01 00:00:00'
              AND count(account_id) > 1)

- должно быть что-то вроде

         SELECT account_id, COUNT(account_id)
             FROM streaming_transactions_detail
             WHERE modified > '2009-09-01 00:00:00'
             GROUP BY account_id
             HAVING count(account_id) > 1)



[не имеет отношения] Я добавлю незапрошенный намек о стиле.
Используя псевдонимы таблиц, вы можете улучшить читаемость запроса. Это можно сделать, добавив необязательно «AS xyz», где xyz - это какое-то короткое, но мнемоническое имя, уникальное для этого запроса. Вы можете использовать xyz в любом месте запроса, где вы используете long_named_table. Например:

FROM streaming_transactions_detail AS D

, а затем

SELECT streaming_transactions.account_id,
   streaming_transactions_detail.transactions_description, 
   streaming_transactions_detail.transactions_detail_id, 
   ...

Может стать (опционально, т.е. "streaming_transactions_detail." Все еще работает)

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