0

我写了一个 PHP/MySQLi 前端,用户可以在其中输入 SQL 查询,然后服务器将结果返回到一个表中(或在INSERTs 和UPDATEs 上打印 OK)

SELECT * FROM movies由于在包含大约 1.6M 电影、1.9M 演员和 3.2M 关键字的 IMDb 提取中打印结果可能需要很长时间(例如),我通过在 50 次迭代后取消打印 for 循环将输出限制为 50 行。

但是,查询本身也需要相当长的时间,所以我希望可以设置一个全局最大行返回值,不管是否使用LIMIT关键字。我只是打算将服务器用于我自己的练习,但是由于我班上的一些人正在努力使用老师提供的前端(Windows EXE,但有一半的班级使用 Mac/Linux),我决定让它可以访问他们也是。但是我想防止我的 Debian VM 崩溃,因为 - 好吧,基本上这将是一个 DDoS。

为了澄清(全局限制为 50 的示例):

SELECT * FROM movies;
> First 50 rows
SELECT * FROM movies LIMIT 10;
> First 10 rows
SELECT * FROM movies LIMIT 50,100;
> 50 rows (from 50 to 99)

是否有可能使用 PHP/MySQLi 或 MySQL 服务器本身来限制返回值的数量?还是我必须LIMIT在查询中附加/替换/替换?

4

3 回答 3

1

您可以使用那里的查询并向其添加“LIMIT 50”。

如果他们自己添加了 LIMIT,只需使用正则表达式将其过滤掉,然后仍然添加您的 LIMIT。

于 2015-03-25T21:30:04.083 回答
0

您可以创建一个函数。 https://dev.mysql.com/doc/refman/5.0/en/create-function.html

让我们知道这是否有帮助。

于 2015-03-25T21:40:56.990 回答
0

我相信无论如何你都必须为自己建立一个分页器,我相信避免使用LIMIT语句是不可能的。

以下是我对 Paginator 的建议:

if($_REQUEST['page'] == ""){
 $page = 1;
}else{
 $page = $_REQUEST['page']; // perhaps double check if numeric
}

$perpage = 50;
$start = ($page - 1) * $perpage;

$limit_string = " LIMIT ". $start . "," . $perpage ;

$query = "SELECT * FROM movies";
$query .= $limit_string;

希望有帮助

于 2015-03-25T21:35:19.340 回答