[英]How to pass a parameter from a form in Symfony and PHP?
我试图用symfony中的PHP实现一个非常简单的搜索功能。
基本上,我有一个发布查询的表单,我想在数据库中检索与查询匹配的项目。
如果我有一个用户表的列first_name和last_name,我希望能够检索包含查询的所有项目。 例如,如果我提交“ a”,我将得到其中包含“ a”的所有名称:
所以我知道我可以通过指定条件来获取表中所有名字都包含“ a”的对象:
$c = new Criteria();
$c->add(UserPeer::FIRST_NAME, '%a%', Criteria::LIKE);
$users = UserPeer::doSelect($c);
有没有办法在add()函数中传递$ query这样的变量? 我可以通过表单获取$ query,然后将其作为变量传递给add函数并获取包含它的所有对象吗? 我什至会以正确的方式这样做吗?
在您的表单上创建一个ID为'query'的输入
<label for="query">Query:</label>
<?php echo input_tag('query') ?>
在操作中,如果已提交表单,则获取参数,然后将其传递到您的条件中
if($this->getRequest()->getMethod() == sfRequest::POST)
{
$query = $this->getRequestParameter('query');
$c = new Criteria();
$c->add(UserPeer::FIRST_NAME, '%'.$query.'%', Criteria::LIKE);
$users = UserPeer::doSelect($c);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.