Как сравнить две таблицы БД с разным количеством строк на основе одного атрибута в 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)
Что я хочу:
- Я хочу сравнить
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