0

我有一个名为的数据库表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 Timestamp 值将日期存储在列中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)

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

4

1 回答 1

1

如果您只是将 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 函数进行日期数学的所有优势。

于 2013-07-12T12:25:12.213 回答