我有一个名为的数据库表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)
任何人都可以在这方面帮助我吗?提前致谢。