使用mysqli multiquery显示搜索结果

时间:2016-10-05 13:00:21

标签: php mysql search mysqli

如何使用mysqli multiquery显示搜索结果。我想显示我的列表详细信息表和我的用户表中的值。这是我的代码:

                $searchquery="SELECT * FROM `listing-details` WHERE `listing-address` LIKE '%" . $address . "%' AND `listing-address-street` LIKE '%" . $street . "%' AND `listing-address-barangay-id` LIKE '%" . $barangay . "%'";
                $searchquery.= "SELECT `user.user-username`, `user.user-firstname`, `user.user-lastname`, `listing-details.user-username` FROM `user`, `listing-details` WHERE `listing-details.user-username`=`user.user-username`";

                if (mysqli_multi_query($conn, $searchquery)) {
                  do {
                    if ($result=mysqli_store_result($conn,$searchquery)){
                      while($row=mysqli_fetch_row($result)){ 
                        $listingid  =$row['listing-id'];
                        $username  =$row['user-username'];
                        $listingbedquantity  =$row['listing-bedquantity'];
                        $listingbedtype =$row['listing-bedtype-id'];
                        $listingguestsquantity  =$row['listing-guestsquantity'];
                        $listingplacetype  =$row['listing-placetype-id'];
                        $listingpropertytype  =$row['listing-propertytype-id'];
                        $listingbathroomquantity =$row['listing-bathroomquantity'];
                        $listingaddress  =$row['listing-address'];
                        $listingstreet  =$row['listing-address-street'];
                        $listingbarangay  =$row['listing-address-barangay-id'];
                        $listingamenities  =$row['listing-amenities-basic-id'];
                        $listingsafetyamenities  =$row['listing-amenities-safety-id'];
                        $listingsaphotos  =$row['listing-amenities-safety-photos-id'];
                        $listingspace  =$row['listing-space-id'];
                        $listinglandmark  =$row['listing-landmark'];
                        $listingpreferences  =$row['listing-preferences-id'];
                        $listingphotoset  =$row['listing-photosset-id'];
                        $listingexperience  =$row['listing-experience-id'];
                        $listingfrequency  =$row['listing-frequency-id'];
                        $listingstartdate  =$row['listing-startdate'];
                        $listingrate =$row['listing-rate-id'];
                        $listingprice  =$row['listing-price'];
                        $listingrules  =$row['listing-rules-id'];
                        $listingtitle  =$row['listing-title'];
                        $listingdescription  =$row['listing-description'];
                        $firstname  =$row['user-firstname'];
                        $lastname  =$row['user-lastname'];

                        echo "<ul>\n";
                        echo "<li>"."<a href=\"search.php?id=$listingid\">" . "<h2>" . $listingtitle . "</h2></a></li>\n";
                        echo "<li><h6>" . $listingaddress . ", " . $listingstreet . ", " . $listingbarangay . "</h6></li>";
                        echo "<li><i>" . $listingdescription . "</i></li>";
                        echo "<ul>\n";
                        echo "<li>"."<a href=\"search.php?id=$listingid\">" . "<h2>" . $listingtitle . "</h2></a></li>\n";
                        echo "<li><h6>" . $listingaddress . ", " . $listingstreet . ", " . $listingbarangay . "</h6></li>";
                        echo "<li><i>" . $listingdescription . "</i></li>";
                        echo "<li style='float:right;'>By: " . $firstname . " " . $lastname . "</i></li>";
                        echo "</ul>";
                        echo "<hr width='80%' noshade='1'>";   

                      }
                      mysqli_free_result($result);
                    } 
                  }                                     
                  while (mysqli_next_result($conn));                     
                }

然而,当我开始运行它时,页面会加载,但结果不会显示。它的目的是能够从用户表中的完整名称列出的列表详细信息表中显示列表详细信息。两个表将user-username列作为公共密钥。

1 个答案:

答案 0 :(得分:0)

与许多学习者一样,你使用错误的工具,只是因为你不知道正确的工具。

你不需要一个多重查询(你实际上从未真正需要)但是 JOIN

只需将您的两个怪物查询重写为此类联接

即可
<a href="about:addons">addons page</a>

此外,你的引用是错误的。