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

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 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值