gpt4 book ai didi

php - 在相同 ID 的倍数上使用 INNER JOIN 从 MYSQL 进行 SELECT

转载 作者:行者123 更新时间:2023-11-29 18:21:49 26 4
gpt4 key购买 nike

所以我只是想知道下一个是否可能,如果可以的话如何解决这个问题。

我创建了一个 INNER JOIN 查询来从一个表中选择多个 ID,其中该 ID 等于另一个表中的 ID 值。

  1. 产品

    product_id  |  cults_id1 |  cults_id2 | cults_id3
    -----------------------------------------------------
    1 | 5 | 4 | 2
    2 | 3 | 0 | 0
  2. 品种

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

所以我创建了一个联接,它将获取所有 cults_name基于产品表cults_id1, cults_id2, cults_id3

结果:

Product_id(1) = mysql! , wood , fruit

现在问题出现在下一个问题上,我如何显示 product_id(2) 的一个值包含。

所以它看起来像这样:

Product_id(1) = mysql! , wood , fruit

Product_id(2) = choc

此刻product_id(2)不会显示在我的列表中,因为它与第一个 ID 之后的 Cultivar 表不相似(使用此查询)。

我知道应该考虑标准化。

查询

   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

现在我的产品列表页面有这个可以在列表中显示它,但我想显示即使 cults_id1, cults_id2, cults_id3值为 0 .

产品列表.php

   <?php
if($result = mysqli_query($conn, $query)){
if(mysqli_num_rows($result) > 0){
$i = 0;
while($row = mysqli_fetch_array($result)){
$i++;

echo "
<p>Cultivars: <span>" .$row["cultivar_type1"]. "</span>, <span>" .$row["cultivar_type2"]. "</span>, <span>" .$row["cultivar_type3"]. "</span>, <span>" .$row["cultivar_type4"]. "</span></p> ";
}
mysqli_free_result($result);
}

}

输出:

  Product_id(1)  =  mysql! , wood , fruit

预期:

  Product_id(1)  =  mysql! , wood , fruit

Product_id(2) = choc

最佳答案

所以我唯一需要做的就是创建一个LEFT JOIN。因为 LEFT JOIN 可以接受 0 或一个值。我的查询成功了。

是的,我的 mysql 数据库没有像预期的那样标准化。

解决方案:

 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
LEFT JOIN wine_cultivar c1 ON c1.cultivar_id = p.cultivar_1_id
LEFT JOIN wine_cultivar c2 ON c2.cultivar_id = p.cultivar_2_id
LEFT JOIN wine_cultivar c3 ON c3.cultivar_id = p.cultivar_3_id
LEFT JOIN wine_cultivar c4 ON c4.cultivar_id = p.cultivar_4_id

关于php - 在相同 ID 的倍数上使用 INNER JOIN 从 MYSQL 进行 SELECT,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46510740/

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