首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >LIMIT在MariaDB中不起作用-尝试了很多方法

LIMIT在MariaDB中不起作用-尝试了很多方法
EN

Stack Overflow用户
提问于 2019-02-20 05:04:26
回答 2查看 387关注 0票数 0
代码语言:javascript
复制
$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‘

代码语言:javascript
复制
$query = "SELECT TOP 10 name FROM lastsearches Order By data DESC";

这就是查询;第一个查询在->中也可以正常工作。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-02-20 05:09:53

实际显示结果的查询如下所示:

代码语言:javascript
复制
$query = "SELECT * FROM lastsearches";
$result = mysqli_query($con, $query);

如果您想限制结果,则需要编辑该查询,即

代码语言:javascript
复制
$query = "SELECT * FROM lastsearches Order By data DESC LIMIT 1";
$result = mysqli_query($con, $query);

我不确定您试图使用while循环中的查询来实现什么,但是它在该循环中没有做任何事情,所以您可能可以删除它。

票数 3
EN

Stack Overflow用户

发布于 2019-02-20 07:09:22

TOP 10是SQL Server语法,而不是MySQL。MySQL使用的LIMIT 10具有非常类似的效果。

既然我在您的代码中没有看到TOP 10,那么它会不会是某个绑定到SQL Server的接口包?

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54774887

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档