0

我做了一个设置操作,在其中我使用教义查询来获取单个结果,但是当数据库中存在数据时它返回 null,我如何获得单个结果?这是我的代码:

public function settingsAction()
    {
            $id = (int) $this->params()->fromRoute('id', 0);
            if (!$id) {
                return $this->redirect()->toRoute('calendar', array(
                    'action' => 'create'
                ));
            }   
                 //echo $id;
            //$calendar = $id;//$this->getCalendarTable()->getCalendar($id);
            $calendar = $documentManager->getRepository('Calendar\Document\Calendar')->find($id);
            $form  = new CalendarForm();
            $form->bind($calendar);
            $form->get('submit')->setAttribute('value', 'Save');

            $request = $this->getRequest();
            if ($request->isPost()) {
                $form->setInputFilter($calendar->getInputFilter());
                $form->setData($request->getPost());

                if ($form->isValid()) {
                    //$this->getCalendarTable()->saveCalendar($form->getData());
                    return $this->redirect()->toRoute('calendar', array('action' => 'show', 'id' => $id));
                }
            }

            return array(
                'id' => $id,
                'form' => $form,
            );
    }
4

1 回答 1

0

您不需要创建查询来按 id 获取,因为DocumentRepository已经通过它的find($id)方法提供了这个。

只需使用文档管理器来获取存储库

$document = $documentManager->getRepository('FooDocument')->find($id);

您也可以find($documentName, $id)直接在文档管理器上使用便捷方法。

$document = $documentManager->find('FooDocument', $id);
于 2014-04-18T14:22:31.633 回答