dtv995719 2009-12-12 00:24
浏览 39
已采纳

Zend_Db和基于日期的查询

I'm using Zend_Db to query a table. I have some WHERE clauses that need to be dates and it's not clear (at first glance) how to do this "the right way". Does Zend_Db provide an abstraction so I don't need to concern myself with how the backend (Oracle, MySQL, etc.) expects its dates? Or do I need to format things in the way my backend expects them.

I'm trying the following with an Oracle based database (PO_DATE is a timestamp field)

$table = $this->getDbTable();               
$select = $table->select()->where('1 = ?', 1);      
$select->where('PO_DATE = ?', '2009-12-02');

and I get the following exception

  <b>Message:</b> 1843 ORA-01843: not a valid month SELECT "TABLE_NAME".* FROM "SYSTEM"."TABLE_NAME" WHERE (1 = 1) AND (PO_DATE = *'2009-12-02')  </p>

I realize I could do something like this

$date = new Zend_Db_Expr(
"to_date('2009-12-02', 'YYYY-MM-DD')"
);
$select->where('PO_DATE = ?', $date);

but that ties me to Oracle's date based Expressions, which partially defeats the purpose of using a SQL abstraction layer.

Is there a generic way to do date queries independent of the back-end implementation with Zend_Db?

  • 写回答

3条回答 默认 最新

  • douya1855 2009-12-12 00:49
    关注

    I would definitely like such a capability, however, I haven't found any in the Zend Framework. This issue in their tracker also makes me pretty confident its not in there yet.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决
  • ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
  • ¥50 分布式追踪trace异常问题
  • ¥15 人在外地出差,速帮一点点
  • ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改