从MYSQL中选择INNER JOIN,使用相同ID的倍数

时间:2017-10-01 08:50:52

标签: php mysql join

所以,我只是想知道下一个是否可行,如果是,如何处理这个问题。

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

  1. 产品

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

      cults_id  |  cults_name |       
      ---------------------------
           1    |  berries    |  
           2    |  fruit      |  
           3    |  choc       |  
           4    |  wood       | 
           5    |  mysql!     | 
      
  2. 所以我创建了一个联接,它将根据产品表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
    

1 个答案:

答案 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