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

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条)

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵