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.

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

报告相同问题?

悬赏问题

  • ¥100 需要跳转番茄畅听app的adb命令
  • ¥50 寻找一位有逆向游戏盾sdk 应用程序经验的技术
  • ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
  • ¥50 opencv4nodejs 如何安装
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证