我有两个表,我想连接和检索一些特定的数据。这些是我的table。
tbl_user (reg_id, l_name, f_name, status)
tbl_payments (pay_id, reg_id, mem_plan, from_date, to_date, bill_no, payed_date)
我需要做的是选择和查看有到期付款的用户。要做到这一点,我想得到用户的详细信息,在哪里 "status=0"
从 tbl_user
将两个表连接在一起,条件是 to_date< current date
,之间的差异 [current date and the to_date] < 31
并按 to_date
.
到目前为止,我所做的是根据上述条件得到一个结果,只是它没有通过 MAX(to_date)
. 这是我的问题。
SELECT
A.reg_id,
A.f_name,
A.l_name,
B.mem_plan,
B.from_date,
Max(B.to_date) AS to_date,
B.bill_no,
B.payed_date
FROM
tbl_user A,
tbl_payments B
WHERE
A.status = 0
AND A.reg_id = B.reg_id
AND Date(Now()) >= Date(B.to_date)
AND Datediff(Date(Now()), Date(b.to_date)) < 31
GROUP BY
a.reg_id, b.mem_plan, b.from_date, b.bill_no, b.payed_date;
我不太熟悉mysql,所以请有人告诉我我做错了什么,或者这个查询是否不符合标准。
下面是一些要处理的示例数据。
tbl\u用户([m1111,jon,doe,0],[m1112,jane,doe,1],[m1113,jony,doe,0])
tbl支付([1,m1111,每月,2018-05-142018-06-14,B1232018-05-14],[2,m1112,3个月,2018-02-032018-05-03,B1122018-02-03],[3,m1113,每月,2018-06-142018-07-14,B1582018-06-14],[4,m1111,每月,2018-06-152018-07-15,B3452018-06-15],[5,m1113,每月,2018-06-062018-07-06,B1582018-06-06],[6,m1111,每月,2018-07-052018-08-05,b345,2018-07-05] )
假设当前日期为2018-07-17,预期结果应为
[m1111,jon,doe,月刊,2018-06-152018-07-15,B3452018-06-15],[m1113,jony,doe,月刊,2018-06-142018-07-14,B1582018-06-14]
相反,我的问题给了我这个。
【m1111,jon,doe,月刊,2018-06-152018-07-15,B3452018-06-15】,【m1113,jony,doe,月刊,2018-06-062018-07-06,B1582018-06-06】,【m1113,jony,doe,月刊,2018-06-142018-07-14,B1582018-06-14】
2条答案
按热度按时间dtcbnfnu1#
我相信
having
在这里不起作用,而且你的第二个查询已经很好了。我把它浓缩到这里:bybem2ql2#
我写了另一个查询,它给出了我想要的结果集。但我不确定是否符合标准。如果有人能简化或使之更好,非常感谢。