我越来越沮丧,因为我不明白为什么在我的SELECT和UNION中我缺少一些字段。 我读了关于这方面的优秀文档,并遵循了最常见的示例,避免在第一个和第二个SELECT之间获得不同数量的列。MySql UNION SELECT缺少字段
它增加了在两个语句之间添加偶数列的NULL列。
这里我的情况:
$query = "(SELECT GC.GroupNO AS GroupNO,
GC.Name AS Name,
GC.Pax AS Pax,
GC.Start AS Start,
NULL AS custid,
NULL AS firstname,
NULL AS lastname,
NULL AS arrivaldate,
NULL AS hour,
NULL AS pax,
NULL AS cctype,
NULL AS created,
NULL AS sid,
NULL AS ref_source,
NULL AS numnights
FROM LargeGroupHostels, GroupContacts AS GC
WHERE LargeGroupHostels.HostelNumber = %d
AND LargeGroupHostels.Status = %s
AND LargeGroupHostels.GroupNO = GC.GroupNO";
AND GC.Start < %s
ORDER BY LastUpdated DESC LIMIT %d, %d
)UNION(
SELECT
NULL AS GroupNO,
NULL AS Name,
NULL AS Pax,
NULL AS Start,
`custid`,
`firstname`,
`lastname`,
`arrivaldate`,
`hour`,
`pax`,
`cctype`,
`created`,
`sid`,
`ref_source`,
datediff(departdate, arrivaldate) AS numnights
FROM customer_details
WHERE hostelnumber = %d
AND lastupdated = "" AND status != "CANX"
AND booking_type IN ("HOSTEL", "HOSTELPACK")
ORDER BY customer_details.arrivaldate, customer_details.created
LIMIT %d, %d)
';
一些的优化和一些变化,我所知道做
除此之外,我的问题在这里: - 为什么我没有拿到列GC.Name,GC.Pax,GC.Start
?如果我反转这两个SELECT,它恰好相反,只考虑GC.Name,GC.Pax,GC.Start
并避开其他列。
我不太习惯这种查询,这是我第一次处理这个问题。我敢肯定,我失去了一些东西,但我不明白是什么
我可能会错过这里的东西 - 但为什么你使用这个工会? Union用于具有相同数据结构的多个查询。这看起来像是在单一结果中将旅舍数据与客户数据结合起来,这可以通过各种连接来完成,并且可能产生更多可读结果 –
第一个查询具有'groupno',第二个查询具有'numnights',而他们不排队。 –
@KaiQing你有理由,但在这种情况下,记录将被安排在一个单一的数组,因为他们有很多共同点,即使名称可能不同。问题是我得到了一个非常大的数组,我需要对提高性能的结果进行分页。我曾尝试使用array_slice进行分页,但加载记录的问题当然存在 –