gpt4 book ai didi

php - INNER JOIN mysql 从一个表到另一个表,它基于相同 id 的倍数

转载 作者:行者123 更新时间:2023-11-29 04:34:43 25 4
gpt4 key购买 nike

我有一个名为 product 的表,它看起来像这样:

产品

  product_id  |  cults_id1 |  cults_id2 | cults_id3
-----------------------------------------------------
1 | 5 | 4 | 2

还有一个基于这个叫做cultivar的表:

品种

  cults_id  |  cults_name | 
-------------------------
1 | berries |
2 | fruit |
3 | choc |
4 | wood |
5 | mysql! |

我将如何创建一个 JOIN 查询以从 cultivar 表中获取每个名称,其中 product 表中的产品 ID 与 cultivar< 中的 cults_id 相同表?

输出

我的产品崇拜:

  berries, Mysql!, wood, fruit

不要认为 INNER JOIN 是可行的方法,但我会尝试这样的事情:

  $query = "SELECT cultivars.cults_name
FROM product
INNER JOIN wine_cultivar ON wine_cultivar.cults_id = product.cultivar_1_id
INNER JOIN wine_cultivar ON wine_cultivar.cults_id = product.cultivar_2_id
INNER JOIN wine_cultivar ON wine_cultivar.cults_id = product.cultivar_3_id
INNER JOIN wine_cultivar ON wine_cultivar.cults_id = product.cultivar_4_id
";

我针对所有 ID 尝试了多次内部连接,但不认为这是可行的方法。这也只是我的 sql 查询的一部分。

最佳答案

只需为每个自连接分配表别名,然后在SELECT 中引用相应的字段。

现在您连接到同一个表,但不提供别名来区分 MySQL 应该提高其 Error #1066 的四个。为了这次尝试。

SELECT p.product_image_path, p.product_id, p.brand_name, p.product_name, b.botttle_size, v.vintage, 
t.wine_type_blend, p.price, p.quantity, p.time_created, p.reference_number, p.shipping_cost,
c1.cultivar_type as cultivar_type1, c2.cultivar_type as cultivar_type2,
c3.cultivar_type as cultivar_type3, c4.cultivar_type as cultivar_type4
FROM product p
INNER JOIN wine_bottle b ON b.bottle_id = p.bottle_id
INNER JOIN wine_vintage v ON v.vintage_id = p.vintage_id
INNER JOIN wine_type t ON t.type_id = p.type_id
INNER JOIN wine_cultivar c1 ON c1.cultivar_id = p.cultivar_1_id
INNER JOIN wine_cultivar c2 ON c2.cultivar_id = p.cultivar_2_id
INNER JOIN wine_cultivar c3 ON c3.cultivar_id = p.cultivar_3_id
INNER JOIN wine_cultivar c4 ON c4.cultivar_id = p.cultivar_4_id

关于php - INNER JOIN mysql 从一个表到另一个表,它基于相同 id 的倍数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46503131/

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