我对 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