$dbhost = "localhost";
$dbuser = "root";
$dbpass = "";
$dbname = "igscript";
$con = mysqli_connect($dbhost, $dbuser, $dbpass, $dbname);
$query = "SELECT * FROM lastsearches";
$result = mysqli_query($con, $query);
if(mysqli_connect_errno()) {
die("DB Error: " . mysqli_connect_error() . " ( " .mysqli_connect_errno() . ")");
}
while($row = mysqli_fetch_assoc($result)) {
$query = "SELECT * FROM lastsearches Order By data DESC LIMIT 1;";
echo '<center><p>'.$row["name"].'</p> </center><hr>';
if(!mysqli_query($con, $query)) {
die('Error : '.mysqli_error($con));
}
}
$result = mysqli_query($con, $query);
无论何时我使用LIMIT 1或LIMIT 10;在$query中,它都没有任何效果。仍然显示相同数量的行。我也尝试过互联网上看到的前10名或前10名,我得到了
错误:您的SQL语法中有一个错误;请查看与您的MariaDB服务器版本对应的手册,以获得正确的语法,以便在第1行使用'10 name FROM lastsearches Order By data DESC LIMIT 1‘
$query = "SELECT TOP 10 name FROM lastsearches Order By data DESC";
这就是查询;第一个查询在->中也可以正常工作。
发布于 2019-02-20 05:09:53
实际显示结果的查询如下所示:
$query = "SELECT * FROM lastsearches";
$result = mysqli_query($con, $query);
如果您想限制结果,则需要编辑该查询,即
$query = "SELECT * FROM lastsearches Order By data DESC LIMIT 1";
$result = mysqli_query($con, $query);
我不确定您试图使用while循环中的查询来实现什么,但是它在该循环中没有做任何事情,所以您可能可以删除它。
发布于 2019-02-20 07:09:22
TOP 10
是SQL Server语法,而不是MySQL。MySQL使用的LIMIT 10
具有非常类似的效果。
既然我在您的代码中没有看到TOP 10
,那么它会不会是某个绑定到SQL Server的接口包?
https://stackoverflow.com/questions/54774887
复制相似问题