将日期结果与 Doctrine 进行比较
Comparing dates results with Doctrine
我用表单生成器编写了一个 api 调用,它创建了两个日期字段。我们的想法是选择两个日期,然后 return 从该日期范围内的数据数据库中得出结果。
我找不到问题出在哪里,但我认为查询生成器中的语法不正确。
我没有收到任何错误,只是一个空数组。
这是一个来自服务api的调用
public function getTransaction()
{
$result = $this->getTransactionRepository()
->createQueryBuilder('a')
->select('a')
->where('a.date >= :from')
->andWhere('a.date <= :to')
->setParameter('from', $date->format('Y-m-d H:i:s'))
->setParameter('to', $date->format('Y-m-d H:i:s'))
->orderBy('p.id')
->getQuery()
->getArrayResult();
return $result;
}
我的控制器
$form = $this->createFormBuilder()
->add('dateFrom', DateType::class, array(
'widget' => 'single_text',
'attr' => array(
'dateFrom' => (new \DateTime())->format('Y-m-d'),
)))
->add('dateTo', DateType::class, array(
'widget' => 'single_text',
'attr' => array(
'dateTo' => (new \DateTime())->format('Y-m-d'),
)))
->add('submit', SubmitType::class, array('label' => 'Send', 'attr' => [
'class' => 'btn-link form-btn'
]))
->getForm();
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$transactions = $this->get('app')->getTransaction();
}
return $this->render('default/finance.html.twig',
array('form' => $form->createView(), 't' => $t)
);
}
和我的树枝视图
<tbody>
<tr>
<th>ID</th>
<th>User</th>
<th>Info</th>
<th>Name</th>
</tr>
{% for a in t %}
<tr>
<td>{{ a.id }}</td>
<td>{{ a.user }}</td>
<td>{{ a.info }}</td>
<td>{{ a.name }}</td>
</tr>
{% endfor %}
</tbody>`
首先,您应该指定您遇到的错误。
无论如何,我不确定,但我会尝试在您的查询生成器中将所有 p.date
替换为 Date
,因为您使用的是 SELECT AS
。此外 DATE
是 MySQL 中的保留关键字,您应该将其替换为其他关键字。
从代码的外观来看,您的 getTransaction
回购函数没有收到它应该收到的 $to
和 $from
DateTime 对象。像这样更新该函数:
public function getTransaction(DateTime $from, DateTime $to) : Collection
{
$result = $this->getTransactionRepository()
->createQueryBuilder('a')
->select('a')
->where('a.date >= :from')
->andWhere('a.date <= :to')
->setParameter('from', $from->format('Y-m-d H:i:s'))
->setParameter('to', $to->format('Y-m-d H:i:s'))
->orderBy('p.id')
->getQuery()
->getArrayResult();
return $result;
}
您的调用应包含现在所需的参数,如下所示:
$transactions = $this->get('app')->getTransaction($from, $to);
我不太确定 FormBuilder
有什么可用的,所以猜测完整的函数调用是:
$transactions = $this->get('app')->getTransaction(
$form->get('dateFrom')->getValue(),
$form->get('dateTo')->getValue(),
);
我用表单生成器编写了一个 api 调用,它创建了两个日期字段。我们的想法是选择两个日期,然后 return 从该日期范围内的数据数据库中得出结果。
我找不到问题出在哪里,但我认为查询生成器中的语法不正确。
我没有收到任何错误,只是一个空数组。
这是一个来自服务api的调用
public function getTransaction()
{
$result = $this->getTransactionRepository()
->createQueryBuilder('a')
->select('a')
->where('a.date >= :from')
->andWhere('a.date <= :to')
->setParameter('from', $date->format('Y-m-d H:i:s'))
->setParameter('to', $date->format('Y-m-d H:i:s'))
->orderBy('p.id')
->getQuery()
->getArrayResult();
return $result;
}
我的控制器
$form = $this->createFormBuilder()
->add('dateFrom', DateType::class, array(
'widget' => 'single_text',
'attr' => array(
'dateFrom' => (new \DateTime())->format('Y-m-d'),
)))
->add('dateTo', DateType::class, array(
'widget' => 'single_text',
'attr' => array(
'dateTo' => (new \DateTime())->format('Y-m-d'),
)))
->add('submit', SubmitType::class, array('label' => 'Send', 'attr' => [
'class' => 'btn-link form-btn'
]))
->getForm();
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$transactions = $this->get('app')->getTransaction();
}
return $this->render('default/finance.html.twig',
array('form' => $form->createView(), 't' => $t)
);
}
和我的树枝视图
<tbody>
<tr>
<th>ID</th>
<th>User</th>
<th>Info</th>
<th>Name</th>
</tr>
{% for a in t %}
<tr>
<td>{{ a.id }}</td>
<td>{{ a.user }}</td>
<td>{{ a.info }}</td>
<td>{{ a.name }}</td>
</tr>
{% endfor %}
</tbody>`
首先,您应该指定您遇到的错误。
无论如何,我不确定,但我会尝试在您的查询生成器中将所有 p.date
替换为 Date
,因为您使用的是 SELECT AS
。此外 DATE
是 MySQL 中的保留关键字,您应该将其替换为其他关键字。
从代码的外观来看,您的 getTransaction
回购函数没有收到它应该收到的 $to
和 $from
DateTime 对象。像这样更新该函数:
public function getTransaction(DateTime $from, DateTime $to) : Collection
{
$result = $this->getTransactionRepository()
->createQueryBuilder('a')
->select('a')
->where('a.date >= :from')
->andWhere('a.date <= :to')
->setParameter('from', $from->format('Y-m-d H:i:s'))
->setParameter('to', $to->format('Y-m-d H:i:s'))
->orderBy('p.id')
->getQuery()
->getArrayResult();
return $result;
}
您的调用应包含现在所需的参数,如下所示:
$transactions = $this->get('app')->getTransaction($from, $to);
我不太确定 FormBuilder
有什么可用的,所以猜测完整的函数调用是:
$transactions = $this->get('app')->getTransaction(
$form->get('dateFrom')->getValue(),
$form->get('dateTo')->getValue(),
);