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

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 #求带 python,使用pycharm爬取智联招聘数据资源并保存为Excel文件,同时以图表形式呈现
  • ¥15 学校优化算法怎么样,国内用的多吗?
  • ¥15 微信购物商城购物车的所有功能以及购物车,和首页的搜索功能
  • ¥40 servlet的web程序部署出错
  • ¥50 activiti 新建流程系列问题
  • ¥50 为什么我版本升级之后运行速度变慢5倍??
  • ¥15 如何在gazebo中加载机械臂和机械手
  • ¥15 纯运放实现隔离采样方案设计
  • ¥20 easyconnect无法连接后缀带.com的网站,一直显示找不到服务器ip地址,但是带有数字的网站又是可以连接上的,如何解决
  • ¥15 电脑开机过商标后就直接这样,求解各位