所以,我只是想知道下一个是否可行,如果是,如何处理这个问题。
我创建了一个INNER JOIN查询来从表中选择多个ID,它等于另一个表中的ID值。
产品表
product_id | cults_id1 | cults_id2 | cults_id3
-----------------------------------------------------
1 | 5 | 4 | 2
2 | 3 | 0 | 0
品种表
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后的品种表不相似(使用此查询)。
我知道应该考虑正常化。
查询
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
,我也希望显示。
产品-listing.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
答案 0 :(得分:0)
所以我唯一要做的就是创建一个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