sql - MySql 计数查询

标签 sql mysql

我正在为一份一次性报告处理这个查询。基本上我想做的是找到上个月单个帐户 ID 超过两笔交易的所有记录。我知道这可能很简单,我的脑子一片空白。

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

最佳答案

我想你快到了。 但是,获取事务 ID 的子查询已关闭

         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 是一些简短但助记的名称,对于此查询是唯一的,您可以在查询中使用 long_named_table 的任何地方使用 xyz。
例如:

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, 
   ...

关于sql - MySql 计数查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1510404/

相关文章:

c# - 如何在现有业务数据之上创建 odbc 层?

MySQL - 如果在表 F 上未找到记录,则从关系表 A、B、C、D、E 中选择数据

mysql - 如何编写一个 sql 查询返回可以用给定项目完成的订单列表

MySQL如何在没有外键的情况下级联删除

sql - 为什么 SQL Server 不断创建 DF 约束?

php - MySQL 带回多个总数

javascript - 尝试使用 javascript/PHP 更新数据库不起作用

php - 使用数据库生成的列表时传递 PHP 变量而不被看到

mysql - codeigniter mysql View 与查询

sql - MySQL 通过查询转储