gpt4 book ai didi

Mysql - 如何在左连接中为整个表添加别名

转载 作者:可可西里 更新时间:2023-11-01 06:32:09 25 4
gpt4 key购买 nike

我遇到这样一种情况,其中一个属性表包含一个地址 ID(来自 g_addresses 表),而一个申请人表包含一个来自 g_addresses 的地址 id。我想将它们连接在一起,但选择表中的所有字段。

我知道使用“as”为字段创建别名,但有什么方法可以为整个表生成别名吗?

SELECT *
FROM (`reference`)
LEFT JOIN `applicants` ON `applicants`.`id` = `reference`.`applicant_id`
LEFT JOIN `g_people` applicant_person ON `applicant_person`.`id` = `applicants`.`person_id`
LEFT JOIN `g_addresses` applicant_address ON `applicant_address`.`id` = `applicants`.`address_id`
LEFT JOIN `properties` ON `properties`.`id` = `reference`.`property_id`
LEFT JOIN `g_addresses` property_address ON `property_address`.`id` = `properties`.`address_id`
WHERE `reference`.`id` = 4

这会产生一个只包含一个地址行而不是两个地址行的结果,返回的行是来自最终连接的行而不是之前的行,表明它在返回时被覆盖。

最佳答案

我认为你不应该使用掩码引用,比如 *`reference`.*,在你的情况下,因为你最终可能会得到一个行集包含相同的列名(idaddress_id)。

如果你想从连接表中提取所有列,你可能应该在 SELECT 子句中单独指定它们并为它们中的每一个分配一个唯一的别名:

SELECT
ref.`id` AS ref_id,
ref.`…` AS …,

app.`id` AS app_id,

FROM `reference` AS ref
LEFT JOIN `applicants` AS app ON app.`id` = ref.`applicant_id`
LEFT JOIN `g_people` AS ape ON ape.`id` = app.`person_id`
LEFT JOIN `g_addresses` AS apa ON apa.`id` = app.`address_id`
LEFT JOIN `properties` AS pro ON pro.`id` = ref.`property_id`
LEFT JOIN `g_addresses` AS pra ON pra.`id` = pro.`address_id`
WHERE ref.`id` = 4

关于Mysql - 如何在左连接中为整个表添加别名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7150209/

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