编程语言
首页 > 编程语言> > PhalconPHP-解析错误时..之前的扫描错误

PhalconPHP-解析错误时..之前的扫描错误

作者:互联网

我正在使用PhalconPHP 1.3.4构建Web应用程序,由于某些值通过关系存储在另一个表中,因此我试图同时从多个表中选择数据.

我的查询在MySQL工作台中工作正常,但是当我尝试使用PhalconPHP执行查询时,出现以下错误:

Scanning error before 'Bookings, Trips]...' when parsing: SELECT count(bkId) AS bookings FROM [Bookings, Trips] WHERE ((bkUserId = :userId:) AND (CURDATE() > tripFromDate)) AND (CURDATE() < DATE_ADD(tripFromDate, INTERVAL 2 WEEK)) (172)

我的PHP代码:

$query = new Builder();
$query->columns("count(bkId) AS bookings");
$query->from('Bookings, Trips');
$query->where("bkUserId = :userId:");
$query->andWhere("CURDATE() > tripFromDate");
$query->andWhere("CURDATE() < DATE_ADD(tripFromDate, INTERVAL 2 WEEK)");
$result = $query->getQuery()->execute(["userId" => $userId])->bookings;
return ($result > 0);

我已经读到这可能是一个错误,但是应该在1.3.2版中修复,我目前在做错什么吗?

我在这里先向您的帮助表示感谢.

解决方法:

我不认为from中的两列是正确的语法.在文档中有以下示例:

$builder->from('Robots')
    ->addFrom('Parts', 'p');

所以你的例子应该是这样的

 $query = new Builder();
    $query->columns("count(b.bkId) AS bookings");
    $query->from('Bookings', 'b');
    $query->addFrom('Trips');
    $query->where("b.bkUserId = :userId:");
    $query->andWhere("CURDATE() > b.tripFromDate");
    $query->andWhere("CURDATE() < DATE_ADD(b.tripFromDate, INTERVAL 2 WEEK)");

要么这样做,要么最好转换为使用联接.

标签:phalcon,mysql,php
来源: https://codeday.me/bug/20191120/2044414.html