我试图从表中检索数据,我想从表中获取所有行,其中一列可能是多个值,即

表格1

Id     User   SiteID
--------------------
 1  -  Ali   -  6
--------------------
 2  -  Ali   -  7
--------------------
 3  -  Ali   -  8
--------------------
 4  -  Jack  -  20
--------------------


因此,在表中,一个Ali拥有站点6,7,8,而jack仅有站点20。现在我有另一张桌子

表2

    Id     Event         Location     SiteID
    -------------------------------------------
     1  -  Fire       -  Room 22      -  101
    -------------------------------------------
     2  -  Fault      -  Reception    -  6
    -------------------------------------------
     3  -  Isolation  -  Student Hall -  7
    -------------------------------------------
     4  -  Bomb Alert -  Floor 3      -  8
    -------------------------------------------


我想从表2中选择数据,其中SiteID是Ali拥有的站点,即Ali拥有SiteID的6,7,8。

因此,最初使用php时,我可以使用以下命令从表1中获取记录:

 $query="SELECT * FROM Table1 WHERE User='Jack'";
                $result = mysqli_query($con,$query) or die(mysql_error());
                while($row11=mysqli_fetch_array($result,MYSQLI_ASSOC)){
                    $site=$row11["SiteID"];
                    echo $mySite;
}


现在我要从表2中选择,其中SiteID是分配给Ali的站点,即站点6,7,8。

因此,我尝试了以下操作,但无法完成任务:

$sql_query="SELECT * FROM Table2 WHERE SiteID='$site' ORDER BY Id DESC LIMIT 300";
                $result_set=mysqli_query($con,$sql_query);

                   while($row=mysqli_fetch_array($result_set,MYSQLI_ASSOC))
                    {

                        echo $row["Event"];
                        echo $row["Location"];
                   }


但是,这并没有给我带来期望的结果。我想要表2中的所有事件和位置,其中站点是表1中Ali拥有的站点,因此所需的结果应为我提供以下信息。

     Id     Event         Location     SiteID
    -------------------------------------------
     2  -  Fault      -  Reception    -  6
    -------------------------------------------
     3  -  Isolation  -  Student Hall -  7
    -------------------------------------------
     4  -  Bomb Alert -  Floor 3      -  8
    -------------------------------------------


谁能建议我可以做到这一点。谢谢

最佳答案

您可以使用一个查询而不是两个查询:

SELECT Table2.*
FROM Table1
INNER JOIN Table2 ON Table1.SiteID = Table2.SiteID
WHERE Table1.User = 'Ali'
ORDER BY Id DESC
LIMIT 300

关于php - 根据table1中的值从table2中选择行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48743864/

10-14 15:24