我要走出大山 2021-06-30 20:55 采纳率: 65%
浏览 282
已采纳

mysql 数据库 datediff() 函数查询报错,查询条件是时间范围+多条件查询语句

如下语句报错,cash_date是数据库中需要查询的字段名称,请懂的解答下,谢谢

注意:本问题要查询的数据表中cash_date字段值的类型是“2021-06-11 20:10:09” PHP中的需拼接的部分查询条件语句是(pdo查询语句):

 if ($keyword['timebucket']) {
        $today = date("YYYY-mm-dd");;
        switch($keyword['timebucket']) {
            case 'today': $condition .= " AND datediff(cash_date,date('YYYY-mm-dd')) = 0 "; break;//今天
            case 'yesterday': $condition .= " AND datediff(cash_date,$today)=1 "; break;//昨天
            case 'week': $condition .= " AND datediff(cash_date,$today)<=7 "; break;//本周
            case 'las_week': $condition .= " AND datediff(cash_date,$today)>7 "; break;//7天前
            case '30today': $condition .= " AND datediff(cash_date,$today)<=30 "; break;//30天内
            case 'month': $condition .= " AND datediff(cash_date,$today)=0 "; break;//本月
            case 'last_month': $condition .= " AND datediff(cash_date,$today)=1 "; break;//上月
            case 'year': $condition .= " AND datediff(cash_date,$today)=0 "; break;//今年
            case 'last year': $condition .= " AND datediff(cash_date,$today)=1 "; break;//去年
        }
    }

完整sql语句及报错如下:

Warning: SQL:
SELECT * FROM `数据表名称` WHERE id = 9 AND datediff(dd,cash_date,'2021-06-30 08:48:11') = 0 AND cash_state = 0 ORDER BY id DESC LIMIT 0,10
Params:
array ( )
SQL Error:
Incorrect parameter count in the call to native function 'datediff'

--------问题补充----------

问题1:语句中的dd热心网友解答需要去掉,去掉dd后如何实现按天、月、年这种时间单位来查询; 如下面的使用场景: a、datediff(day,cash_date,$today)<=30 "; //30天内 b、datediff(month,cash_date,$today)=0 "; //本月 c、datediff(year,cash_date,getdate())=1 "; //去年

问题2:datediff(dd,cash_date,getdate()) ,该语句中当前时间获取方式getdate()写法是否错误,应该用什么写法? 问题3:注意:本问题要查询的数据表中cash_date字段值的类型是“2021-06-11 20:10:09”,所以第二个参数是否也要用'Y-m-d H:i:s'的时间格式对应上?

  • 写回答

3条回答 默认 最新

  • 关注
    SELECT * FROM `数据库名称` WHERE id = 9 AND datediff(dd,cash_date,'2021-06-30 08:48:11') = 0 AND cash_state = 0 ORDER BY id DESC LIMIT 0,10
    改为
    SELECT * FROM `数据库名称` WHERE id = 9 AND datediff(cash_date,'2021-06-30') = 0 AND cash_state = 0 ORDER BY id DESC LIMIT 0,10
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥15 键盘指令混乱情况下的启动盘系统重装