我正在创建一个客户有多个预订的实例。为此,每次在预订表中多次列出客户编号时,这表示他们有多个预订(这也是条件)。不幸的是,当我尝试运行此查询时,我得到:
Error Code: 1111 (Invalid use of group function).
这是我在下面所做的。
SELECT FirstName, LastName, tripName
FROM reservation, customer, trip
WHERE reservation.CustomerNum = customer.CustomerNum
AND reservation.TripID = trip.TripID
AND COUNT(reservation.CustomerNum) > 1
GROUP BY reservation.CustomerNum;
我是 SQL 的新手,任何建议都会很有帮助。
最佳答案
您需要编写正确的联接,使用别名有助于保持内容的可读性并节省您的额外击键次数,并且您需要使用类似这样的方法将结果限制为具有多个保留的结果:
select FirstName, LastName, tripName
from customer c
inner join reservation r
on c.CustomerNum = r.CustomerNum
inner join trip t
on r.TripID = t.TripID
where c.CustomerNum in (
select ir.CustomerNum
from reservation ir
group by ir.CustomerNum
having count(*) > 1
)
关于mysql - 遇到 SQL 错误 1111 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43005017/