mysql叠加select,MySQL – 有效地将两个select语句组合成一个...

您可以将多个查询与UNION组合,但前提是查询具有相同的列数.理想情况下,列不仅在数据类型中,而且在于它们的语义含义;但是,MySQL并不关心语义,并且会通过强制转换为更通用的东西来处理不同的数据类型 – 因此,如果有必要,您可以重载列以使每个表具有不同的含义,然后确定在更高级代码中适当的含义(虽然我不建议这样做).

当列数不同时,或者想要从两个查询中实现更好/更少重载的数据对齐时,可以在SELECT语句中插入虚拟文本列.例如:

SELECT t.cola, t.colb, NULL, t.colc, NULL FROM t;

您甚至可以为第一个表保留一些列,为第二个表保留其他列,这样它们在其他地方是NULL(但请记住,列名来自第一个查询,因此您可能希望确保它们都在那里命名) :

SELECT a, b, c, d, NULL AS e, NULL AS f, NULL AS g FROM t1

UNION ALL -- specify ALL because default is DISTINCT, which is wasted here

SELECT NULL, NULL, NULL, NULL, a, b, c FROM t2;

您可以尝试以这种方式对齐您的两个查询,然后将它们与UNION运算符组合;通过将LIMIT应用于UNION,您即将实现目标:

(SELECT ...)

UNION

(SELECT ...)

LIMIT 10;

剩下的唯一问题是,如上所述,来自第一个表的10个或更多记录将“推出”来自第二个表的任何记录.但是,我们可以在外部查询中使用ORDER BY来解决此问题.

把它们放在一起:

(

SELECT

dr.request_time AS event_time, m.member_name, -- shared columns

dr.request_id, dr.member1, dr.member2, -- request-only columns

NULL AS alert_id, NULL AS alerter_id, -- alert-only columns

NULL AS alertee_id, NULL AS type

FROM dating_requests dr JOIN members m ON dr.member1=m.member_id

WHERE dr.member2=:loggedin_id

ORDER BY event_time LIMIT 10 -- save ourselves performing excessive UNION

) UNION ALL (

SELECT

da.alert_time AS event_time, m.member_name, -- shared columns

NULL, NULL, NULL, -- request-only columns

da.alert_id, da.alerter_id, da.alertee_id, da.type -- alert-only columns

FROM

dating_alerts da

JOIN dating_alerts_status das USING (alert_id, alertee_id)

JOIN members m ON da.alerter_id=m.member_id

WHERE

da.alertee_id=:loggedin_id

AND da.type='platonic'

AND das.viewed='0'

AND das.viewed_time

ORDER BY event_time LIMIT 10 -- save ourselves performing excessive UNION

)

ORDER BY event_time

LIMIT 10;

当然,现在由您决定在读取结果集中的每条记录时确定要处理的行类型(建议您对NULL值测试request_id和/或alert_id;或者可以在结果中添加一个额外的列它明确说明每个记录来自哪个表,但它应该是等效的,只要那些id列是NOT NULL).

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值