簡體   English   中英

使用同一個ID的倍數進行INNER JOIN的MYSQL選擇

[英]SELECT from MYSQL with INNER JOIN on multiples of the same ID

因此,我只是想知道下一個是否可能,以及如何解決這個問題。

我創建了一個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! | 

所以,我創建了一個參加在那里將獲取所有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 cults_id1, cults_id2, cults_id3我也要顯示它。

產品清單.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 DB所期望的標准化。

解:

 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 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM