Как сравнить две таблицы БД с разным количеством строк на основе одного атрибута в MySql?

Что я имею:

1.У меня две таблицы БД display а также bid как указано ниже:

mysql> select * from display where gp_no = 1;

+-------+--------------+-----------+--------------------+---------------+-----------+----------------+
| gp_no | no_of_member | amount    | current_instalment | starting_date | member_no | member_name    |
+-------+--------------+-----------+--------------------+---------------+-----------+----------------+
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |         1 | Akansha Gupta  |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |         2 | Akash Bansal   |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |         3 | Ashish Gupta   |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |         4 | Chavi Jain     |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |         5 | Dhruv Goel     |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |         6 | Mukul Gupta    |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |         7 | Nancy Aggarwal |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |         9 | Prateek Jain   |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |        11 | Rajender Gupta |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |        12 | S K Goel       |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |        13 | Sadhna Goel    |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |        15 | Sandeep Jain   |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |        16 | Sunil Jain     |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |        17 | Sunil Sharma   |
|     1 |           15 | 375000.00 |                  2 | 2015-05-01    |        19 | Sunita Gupta   |
+-------+--------------+-----------+--------------------+---------------+-----------+----------------+
15 rows in set (0.00 sec)

mysql> select date , member_no from bid where gp_no = 1 order by member_no asc;
+------------+-----------+
| date       | member_no |
+------------+-----------+
| 2015-06-01 |         7 |
| 2015-05-01 |        16 |
+------------+-----------+
2 rows in set (0.00 sec)

Что я хочу:

  1. Я хочу сравнить member_no Из обеих таблиц и где я получаю совпадение. Должна отображаться дата из таблицы. bid иначе должно отображаться Not Withdraw. С помощью кода, который я использую, я могу отображать только первую дату, т.е. только первое совпадение. Я, наверное, знаю, что это из-за несоответствия в нет. строк обеих таблиц.

Это то, что я получаю

Но он также должен отображать дату перед member_no = 16,

Код PHP

$sql = "select * from display where gp_no = '$gp_no' ";
$result = mysqli_query($conn, $sql);

$s_no = 1 ; 
if (mysqli_num_rows($result) > 0)
{


 $s = " select date,member_no  from bid where gp_no = '$gp_no ' order by member_no asc"; 
 $r = mysqli_query($conn, $s);
 if (mysqli_num_rows($r) > 0)
  {
    ?> <h1>Welcome !!! Details of GROUP NO : <?php echo $gp_no ;  ?></h1> 
     <table  align = center ; style="width:50%">
     <tr><th><?php echo " Group Number ";?> </th><td><?php echo $gp_no ; ?></td></tr>
     <tr><th><?php echo " Number of Members ";?> </th><td><?php echo $no_of_member ; ?></td></tr>
     <tr><th><?php echo " Amount ";?> </th><td><?php echo $amount ; ?></td></tr>
     <tr><th><?php echo " Starting Date ";?> </th><td><?php echo $starting_date ; ?></td></tr>
     <tr><th><?php echo " Current Instalment ";?> </th><td><?php echo $current_instalment ; ?></td></tr>
     </table>
     <table  align = center ; style="width:50%" id = " display">
    <tr><th><?php echo "  Sr. Number ";  ?> </th><th><?php echo "  Member Number ";  ?> </th><th><?php echo "  Member Name ";  ?> </th><th><?php echo "  Bid Withdraw ";  ?> </th></tr>
   <?php
   /*$row_count = mysqli_num_rows($result);
   $row1_count = mysqli_num_rows($r);
   $remaining_rows = max($row_count, $row1_count);
   while($remaining_rows-- > 0)
{
    $row = mysqli_fetch_assoc($result);
    $row1 = mysqli_fetch_assoc($r); */
     while($row1 = mysqli_fetch_assoc($r))
     {
         while($row = mysqli_fetch_assoc($result))
    { 


      ?>
     <tr>
        <td><?php echo $s_no ; ?></td>

        <td><?php echo $row["member_no"] ; ?></td>

        <td><?php echo $row["member_name"] ; ?></td>
    <?php
     if($row["member_no"] === $row1["member_no"])
    {
    ?>
       <td><?php echo $row1["date"] ; ?></td>
    <?php 
     }
    else
     { ?> 
       <td><?php echo " Not withdrawn "; ?></td> 
       <?php } ?> 
   </tr> 
  <?php
       $s_no = $s_no + 1;
        }
        } 
        ?>
  </table>  
      <?php 
        }
            } 
    else
    {
    ?> <h1>  Members not associated yet. </h1> <?php
    }
   }
  mysqli_close($conn);
 ?>

4 ответа

Решение

Попробуйте этот запрос, он должен работать согласно вашему требованию

SELECT d.member_no, d.member_name, IFNULL(b.date, 'NOT WITHDRAWN')
FROM display d LEFT JOIN bid b ON d.member_no = b.member_no
and b.gp_no='1' where d.gp_no='1'

Почему бы вам не использовать OUTER JOIN, что-то вроде этого

SELECT d.member_no, b.date
FROM display d LEFT JOIN bid b ON d.member_no = b.member_no
WHERE d.gp_no = 1 AND b.gp_no = 1  

Попробуй это

SELECT d.member_no,d.member_name,CASE WHEN b.date IS NULL THEN 'Not Withdraw' ELSE b.date END AS bidDate 
FROM display AS d 
LEFT JOIN bid AS b ON d.member_no=b.member_no AND d.starting_date = b.date
WHERE d.gp_no=1

Попробуйте этот запрос

SELECT d.member_no,d.member_name,CASE WHEN b.date IS NULL THEN 'Not Withdraw' ELSE b.date END AS bidDate FROM display AS d LEFT JOIN bid AS b ON d.member_no=b.member_no WHERE d.gp_no=1
Другие вопросы по тегам