gpt4 book ai didi

php - 对于以下场景,如何使用 SQL 查询显示按月结果?

转载 作者:行者123 更新时间:2023-11-29 13:44:30 25 4
gpt4 key购买 nike

我有一个名为user_transaction的数据库表,其结构如下:

transaction_id    mediumint(6)   UNSIGNED (PK)
transaction_no varchar(55)
transaction_cc_avenue_no varchar(55)
transaction_card_category varchar(100)
transaction_user_id varchar(32)
transaction_user_name varchar(255)
transaction_user_email_id varchar(255)
transaction_deal_code varchar(10)
transaction_dc_id smallint(4)
transaction_amount float(10,2)
transaction_discount float(10,2)
transaction_total_amount float(10,2)
transaction_data_assign enum('0', '1')
transaction_status enum('success', 'inprocess', 'fail', 'cancelled')
transaction_date bigint(12)
transaction_update_date bigint(12)
transaction_update_user_id varchar(32)

我使用 UNIX 时间戳值将日期存储在 transaction_date 列中。现在我想显示每月的编号。表中存在的所有 transaction_dates 的不同 transaction_status 的交易数量(即每个日期发生的总交易量,状态为“成功”、“处理中”、“失败”和“已取消”的交易总数)。这些记录应按月分组。我做了很多尝试来获得这个结果,但没有取得任何成功。为了供您引用,我在下面给出了我的查询:

SELECT COUNT(*) `total count`, SUM(transaction_status = 'success') `success`, SUM(transaction_status = 'inprocess') `inprocess`, SUM(transaction_status = 'fail') `fail`, SUM(transaction_status = 'cancelled') `cancelled` FROM user_transaction GROUP BY FROM_UNIXTIME(transaction_date)

有人可以在这方面帮助我吗?提前致谢。

最佳答案

如果你只是将 transaction_date 设置为日期会容易得多。然后就可以使用内置函数了。

例如,你可以这样做

SELECT year(transaction_date), month(transaction_date),
sum(whatever), ...
FROM user_transaction
GROUP BY YEAR(transaction_date), MONTH(transaction_date)
ORDER BY YEAR(transaction_date), MONTH(transaction_date);

如果您不愿意更改 transaction_date 的数据类型,那么您可以使用 FROM_UNIXTIME 即时转换它。我不建议这样做,因为它是每个查询中额外的(不必要的)处理层。尽管如此,这意味着您可以保持架构不变并编写:

SELECT year(FROM_UNIXTIME(transaction_date)), month(FROM_UNIXTIME(transaction_date)),
sum(whatever), ...
FROM user_transaction
GROUP BY YEAR(FROM_UNIXTIME(transaction_date)), MONTH(FROM_UNIXTIME(transaction_date))
ORDER BY YEAR(FROM_UNIXTIME(transaction_date)), MONTH(FROM_UNIXTIME(transaction_date));

很恶心不是吗?您最好执行“ALTER TABLE CHANGE COLUMN transaction_date transaction_date date”,然后您将获得使用易于使用的 MySQL 函数进行日期数学运算的所有优势。

关于php - 对于以下场景,如何使用 SQL 查询显示按月结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17614640/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com