gpt4 book ai didi

php - MySQL 和 PDO,加速查询并从 MySQL 函数(例程)获取结果/输出?

转载 作者:行者123 更新时间:2023-11-29 02:17:52 25 4
gpt4 key购买 nike

获取值(value):

我有 levenshtein_ratio 函数,来自 here ,在我的 MySQL 数据库中排队。我按以下方式运行它:

    $stmt = $db->prepare("SELECT r_id, val FROM table WHERE levenshtein_ratio(:input, someval) > 70");
$stmt->execute(array('input' => $input));
$result = $stmt->fetchAll();

if(count($result)) {
foreach($result as $row) {
$out .= $row['r_id'] . ', ' . $row['val'];
}
}

而且效果很好,完全符合预期。但我想知道,有没有一种很好的方法来获得 levenshtein_ratio() 的值?计算?

我试过:

    $stmt = $db->prepare("SELECT levenshtein_ratio(:input, someval), r_id, val FROM table WHERE levenshtein_ratio(:input, someval) > 70");
$stmt->execute(array('input' => $input));
$result = $stmt->fetchAll();

if(count($result)) {
foreach($result as $row) {
$out .= $row['r_id'] . ', ' . $row['val'] . ', ' . $row[0];
}
}

确实在技术上有效(我从 $row[0] 得到百分比),但查询有点难看,我不能使用正确的键来获取值,比如我可以为其他两个项目。

有没有办法以某种方式为它获得一个很好的引用?

我试过:

$stmt = $db->prepare("SELECT r_id, val SET output=levenshtein_ratio(:input, someval) FROM table WHERE levenshtein_ratio(:input, someval) > 70");

根据我在网上找到的东西对其进行建模,但它没有用,最终破坏了整个查询。

加速:

我正在为一组值运行此查询:

foreach($parent as $input){
$stmt = ...
$stmt->execute...
$result = $stmt->fetchAll();

... etc
}

但最终速度非常慢。像 20s 慢,对于只有 14 个输入的数组和一个大约 350 行的数据库,预计很快就会达到 10,000 行。我知道将查询放在循环中是一件很麻烦的事,但我不确定还有什么办法可以解决这个问题。

编辑 1

当我使用

$stmt = $db->prepare("SELECT r_id, val SET output=levenshtein_ratio(:input, someval) FROM table WHERE levenshtein_ratio(:input, someval) > 70");

肯定会花费两倍的时间,就好像我只计算了一次一样?类似于 $i < sizeof($arr);在 for 循环中?

最佳答案

要清理列名,您可以使用“as”来重命名函数的列。同时,您可以通过在 where 子句中使用该列名称来加快速度,这样该函数只执行一次。

$stmt = $db->prepare("SELECT r_id, levenshtein_ratio(:input, someval) AS val FROM table HAVING val > 70");

如果它仍然太慢,你可以考虑像 https://github.com/juanmirocks/Levenshtein-MySQL-UDF 这样的 c 库

doh - 如 spencer7593 所述,忘记将“where”切换为“having”。

关于php - MySQL 和 PDO,加速查询并从 MySQL 函数(例程)获取结果/输出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36679527/

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