gpt4 book ai didi

php - Free Fat Framework a Select with ILIKE Postgresql Statement

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

我对 F3 框架有疑问。

我正在尝试搜索用户输入的一些文本。

这里有一些声明:

$db->exec(array("Select userid,username,section from user 
WHERE section=:sectionId
AND username ILIKE '%?%'"),
array(':sectionId' => $sectionId),
array( 1=> $queryString),
NULL));

如果有一些打字错误,抱歉,但我不允许从生产系统发布代码。

此语句返回一个空数组。

我已经用字符串替换了变量并用 psql 对其进行了测试,但它返回了一个匹配项。

有人有想法吗?

编辑:

来自 Sn0opy 的回答:

$db->exec(array("Select userid,username,section from user 
WHERE section=:sectionId
AND username ILIKE '%?%'"),
array(':sectionId' => $sectionId, 1 => $queryString));

问题是,在 Postgresql 中它是 $1,$2,$3 而不是 '?' .

我的解决方案(再次感谢 Sn0opy 的回复):

你必须连接字符串

('%'|| :queryString || '%')

现在可以了:

$db->exec(array("Select userid,username,section from user 
WHERE section=:sectionId
AND username ILIKE ('%'|| :queryString || '%') ),
array(':sectionId' => $sectionId, ':queryString' => $queryString));

如果你不连接字符串,你会得到这个错误:

ERROR:  could not determine data type of parameter $1

最佳答案

您从 the docs 获得了此代码.如果您重新检查文档,您将看到第一个数组包含三个元素。第二个也是。在您的情况下,您在第一个元素中有一个元素,在最后一个元素中有 3 个元素。只有第一个参数 array(':sectionId' => $sectionId) 会被应用。

这个应该可以工作:

      $db->exec(array("Select userid,username,section from user 
WHERE section=:sectionId
AND username ILIKE '%?%'"),
array(':sectionId' => $sectionId, 1 => $queryString));

关于php - Free Fat Framework a Select with ILIKE Postgresql Statement,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15757022/

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