dounieyan2036 2012-12-30 16:49
浏览 33
已采纳

ZF2,在Db \ SQL中使用WHERE

I'm trying to build a SQL object using ZF2's Db\SQL.

Below is my code.

    $sql = new Sql($this->database);
    $predicate = new Where();
    $query = $sql->select();
    $query->from('sessions');
    $query->columns(array('sessiondata'));
    $query->where($predicate->equalTo('sessionid', $sessionId));
    $query->where($predicate->greaterThan('expire', new Expression("NOW()")));

As you can read, I'm doing a session read.

The preparing is failing on the execute because of the [last] where property:

$query->where($predicate->greaterThan('expire', 'NOW()'));

Unfortunately, ZF2 doesn't tell me why it's failed, all I know is that Statement could not be executed

What am I doing wrong in the above?

I think that prepare is interpreting the thing as literally as it can, hence the presence of the mysql function Now() is causing it to fail. How do I get past this?

EDIT: Actually, it's the execution that's failing.

  • 写回答

1条回答 默认 最新

  • donglian6625 2012-12-30 17:32
    关注

    Try debug the final query. You can use mysql query logger for that. In my.cnf(or my.ini) you set:

    log = "C:/genquery.log"

    OR

    log = "/var/log/mysql/error.log"

    depending on system.

    Then reset mysql server and you can analyze what really happened.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥15 关于超局变量获取查询的问题
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集
  • ¥15 在启动roslaunch时出现如下问题
  • ¥15 汇编语言实现加减法计算器的功能
  • ¥20 关于多单片机模块化的一些问题