gpt4 book ai didi

php - 使用 php 优化 SQL 查询

转载 作者:行者123 更新时间:2023-11-29 08:29:15 24 4
gpt4 key购买 nike

数据库中有 700,000 个元素我有一个关于 id 的索引我还有一个省份索引,一个长度为 30 的 varchar(尽管我认为最大省份的名称长度为 12)

所以

    Create table (
id serial primary key watever,
price double not null,
address varchar(200)not null,
province varchar(30)not null,
description text not null,
status varchar(8) not null,
type varchar(30) not null,
category text not null,
size int(11) not null,
bultin int(4),
bed int(2),
bath int(2),
extras text,
posted_by int foregin key(user.id or whatever)
);

此页面大约需要 2 秒

    $sqlquery = "SELECT DESCRIPTION, ADDRESS, SIZE, BUILTIN, BED, BATH, PRICE 
FROM listings
WHERE PRICE BETWEEN $min and $max AND BED between $minbr AND $maxbr AND CATEGORY =
'$cat' AND TYPE = '$type' AND PROVINCE like '%$province%'";

while ($row = mysqli_fetch_array($listings)) {

echo $row['DESCRIPTION'] . " Located at " . $row['ADDRESS'] . " " . $province. " "
. $row['SIZE'] . " sqft" . ", built in " . $row['BUILTIN'] . " " . $row['BED'] . "Bedroom, "
. $row['BATH'] . " Bathroom for $" . $row['PRICE'] . "
<br>
";

我已经阅读了一些关于提高 SQL 查询效率的教程,但是它们根本没有改变正在发生的事情的速度。 (也许所有速度损失都在 PHP 中?!?我认为这很有可能,如果是这样我该如何优化 php?)

编辑:在 phpmyadmin 上我运行了查询,它花了与运行 php 页面一样长的时间。问题显然是查询而不是 PHP。

最佳答案

如果您不知道索引如何工作,可以从在 WHEREORDER BY 部分中使用的所有列添加索引开始。这远非最佳,但在大多数情况下这是一种改进。最好检查一下explain或使用optimizer .

首先,确保在 PriceBedCategoryType 上也有索引.

另一件事是,您提到您的 Province 列上有一个 index ,但不幸的是,如果您使用 LIKE ,则不会使用该索引开头的通配符。它只会使用第一个通配符之前的部分和索引。所以基本上,无论您有什么索引,这都将是全表扫描。

您可以尝试 FULLTEXT索引以加快速度。

关于php - 使用 php 优化 SQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17106763/

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