首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySql计数查询

MySql计数查询
EN

Stack Overflow用户
提问于 2009-10-02 15:54:40
回答 1查看 95关注 0票数 1

我有一个查询,我正在处理一个一次性报告。基本上,我要做的是找到上个月通过单个帐户ID有两个以上交易的所有记录。我知道这可能是一件容易的事情,我的大脑就是一片空白。

代码语言:javascript
复制
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
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2009-10-02 16:02:24

我想你就快到了。但是,用于获取事务Ids的子查询为off

代码语言:javascript
复制
         SELECT account_id
              FROM streaming_transactions_detail
              WHERE modified > '2009-09-01 00:00:00'
              AND count(account_id) > 1)

--应该是这样的

代码语言:javascript
复制
         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。

例如:

代码语言:javascript
复制
FROM streaming_transactions_detail AS D

然后

代码语言:javascript
复制
SELECT streaming_transactions.account_id,
   streaming_transactions_detail.transactions_description, 
   streaming_transactions_detail.transactions_detail_id, 
   ...

可以变成(可选的,即“streaming_transactions_detail”。仍然有效)

代码语言:javascript
复制
SELECT D.account_id,
   D.transactions_description, 
   D.transactions_detail_id, 
   ...
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1510404

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档