gpt4 book ai didi

mysql - 高级 MySQL 查询

转载 作者:行者123 更新时间:2023-11-29 12:42:55 24 4
gpt4 key购买 nike

  Employees
EmpID : int(10)
Firstname: varchar(100)
Lastname: varchar(100)
HireDate: timestamp
TerminationDate: timestamp

AnnualReviews
EmpID: int(10)
ReviewDate: timestamp

计算公司没有雇用或解雇任何人的最长时间(以天为单位)的查询是什么?

到目前为止,这是我的查询:

SELECT max(abs(datediff((select max(terminationdate) 
from employees
where terminationdate < t.terminationdate),
terminationdate))),
max(abs(datediff((select max(hiredate)
from employees
where hiredate < t.hiredate),
hiredate)))
FROM employees AS t

我不知道如何比较同一字段中每一行的日期..

最佳答案

尽管如此,这仍然是一项艰巨的任务......

 SELECT x.date, MIN(y.date) y_date,DATEDIFF(MIN(y.date),x.date) days
FROM
(
SELECT hiredate date FROM employees
UNION
SELECT terminationdate FROM employees
) x
JOIN
(
SELECT hiredate date FROM employees
UNION
SELECT terminationdate FROM employees
UNION
SELECT CURDATE())
y
ON y.date > x.date
GROUP BY x.date
ORDER BY days DESC LIMIT 1;

关于mysql - 高级 MySQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25866256/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com