我对F3框架有疑问。
我正在尝试搜索一些由用户输入的文字。
这里有一些陈述:
$db->exec(array("Select userid,username,section from user
WHERE section=:sectionId
AND username ILIKE '%?%'"),
array(':sectionId' => $sectionId),
array( 1=> $queryString),
NULL));
如果有一些错误抱歉,但我不允许从生产系统发布代码。
此语句返回一个空数组。
我已经用Strings替换了变量并用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
答案 0 :(得分:2)
您可以从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));