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

标签 php mysql sql unix-timestamp

我有一个名为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/

相关文章:

php - 多线终端进度指示器?

php - 传递 .$row[something] 的值以执行另一个查询

MySQL 外连接替代

sql - 根据列中的重复项选择行

php - 更新命令在 PHP 中无法正常工作

php - 输入字段数据与DB比较并显示db的另一个值

Wordpress 帖子中的 PHP - 这可以吗?

mysql - MySQL 中的 CONCAT()

sql - 3 表加入计算百分比

MySQL触发器正则表达式不工作