gpt4 book ai didi

PHP PDO mysql 按结果 ID 获取行

转载 作者:行者123 更新时间:2023-11-29 23:21:07 25 4
gpt4 key购买 nike

我有一个奇怪的问题。假设我有一个像这样的数字数组:

$positions = array(1, 2, 5, 9, 25, 68, 130);

然后我在一个包含 300 条记录的表上运行数据库查询

$stmt = dbpdo::$conn->query("SELECT * FROM table"); // 300 rows/records

有没有办法我只能根据我的位置数组获取某些行(结果)?例如

$stmt->fetch(row #1);
$stmt->fetch(row #9);
$stmt->fetch(row #68);

最佳答案

您希望编写查询以最大程度地减少返回的数据量。像这样的东西:

SELECT *
FROM table
WHERE id IN (1, 2, 5, 9, 25, 68, 130)

否则,数据库将在每次请求时向您发送表中所有数据的 100%,而不仅仅是您感兴趣的 7 行。

您还可以使用LIMIT 1,$offset从结果集的开头获取单个记录$offset行。 但是,这样的效率要低得多。 MySQL 仍然计算 100% 的结果集,然后简单地迭代它,直到到达第 N 条记录。

理想情况下,您还希望将查询限制为仅返回有限的列集而不是 *。这将减少应用程序的开销。

编辑

回应@serg的建议。 ORDER BY RAND() 简直是魔鬼。除非您 1,000,000% 确定整个结果集 [忽略 LIMIT 子句,LIMIT 对这有多糟糕没有影响!] 永远不会大于几十行,并且您可以完全丢弃所有索引。

说真的,不要这样做。

关于PHP PDO mysql 按结果 ID 获取行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27284830/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com