MYSQL从连接表中选择最大日期

标签 mysql sql database select max

我有 2 个表,我想连接并检索一些特定数据。这些是我的 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_user ( [M1111,乔恩,多伊,0], [M1112,简,多伊,1],[M1113,乔尼,多伊,0] )

tbl_ payment ( [1,M1111,每月,2018-05-14,2018-06-14,b123,2018-05-14],[2,M1112,3个月,2018-02-03,2018-05- 03,b112,2018-02-03],[3,M1113,月刊,2018-06-14,2018-07-14,b158,2018-06-14],[4,M1111,月刊,2018-06- 15,2018-07-15,b345,2018-06-15],[5,M1113,每月,2018-06-06,2018-07-06,b158,2018-06-06],[6,M1111,月刊,2018-07-05,2018-08-05,b345,2018-07-05] )

假设当前日期是2018-07-17,预期结果应该是这样

[M1111,乔恩·多伊,月刊,2018-06-15,2018-07-15,b345,2018-06-15],[M1113,乔恩·多伊,月刊,2018-06-14,2018- 07-14,b158,2018-06-14]

取而代之的是,我的查询给了我这个。

[M1111,乔恩·多伊,月刊,2018-06-15,2018-07-15,b345,2018-06-15],[M1113,乔恩·多伊,月刊,2018-06-06,2018- 07-06,b158,2018-06-06], [M1113,Jony,Doe,月刊,2018-06-14,2018-07-14,b158,2018-06-14]

最佳答案

我编写了另一个查询,它给出了完全符合我想要的结果集。但不知道是否符合标准。如果有人可以简化它或使其变得更好,非常感激。

SELECT A.reg_id,A.f_name,A.l_name,D.mem_plan,D.from_date,D.to_date,D.bill_no,D.payed_date
FROM tbl_user A
JOIN (SELECT B.reg_id,B.mem_plan,B.from_date,B.to_date,B.bill_no,B.payed_date
FROM tbl_payments B
JOIN (
SELECT reg_id, MAX(to_date) as to_date
FROM tbl_payments
WHERE DATE(NOW()) >= DATE(to_date) AND DATEDIFF(DATE(NOW()), DATE(to_date))<31
GROUP BY reg_id) C
ON B.reg_id = C.reg_id AND B.to_date= C.to_date) D
ON A.reg_id = D.reg_id
WHERE A.status=0;

关于MYSQL从连接表中选择最大日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51382443/

相关文章:

database - 重新加载 Datagrid View 不返回任何内容

ruby-on-rails - *显示* View 始终显示数据库中的第一个引脚(项目)

sql - 在 MYSQL 中使用 SELECT DISTINCT

php - Mysql( Doctrine )正在重复计数结果,可能是由于分组依据,但无法弄清楚

c# - C# 中的更新语句

mysql - MSSQL BIT_COUNT(汉明距离)

php - 上传 .txt 文件并将内容插入数据库

mysql - 如何在一行中显示 mysql 表?

PHP-MySQL : Create variable for undefined index

php - 用于 PHP 的 SQL Builder,具有 JOIN 支持?