开发者社区> 问答> 正文

PolarDB datetime类型空字符串比较报错

已解决

PolarDB datetime类型空字符串比较报错

展开
收起
提个问题 2024-06-15 12:09:52 53 0
1 条回答
写回答
取消 提交回答
  • 开发者社区问答官方账号
    官方回答
    采纳回答
    在PolarDB 8.0.2版本中,一个datetime类型的字段,如果与''这样的空字符串比较会导致查询报错:  Incorrect DATETIME value: '',但在8.0.1版本中则可以正常执行,这是一个预期的行为,原因是社区MySQL在8.0.16版本中引入了这一行为,不允许datetime字段与空字符串的比较,PolarDB 8.0.1基于社区8.0.13版本而8.0.2则基于社区8.0.18版本,因此导致了同样的报错行为

    建议修改SQL语句,将空字符串修改为 STR_TO_DATE('','%m-%d-%Y %H:%i:%s'),可以正常执行查询,此时STR_TO_DATE的函数结果将空字符串转为 NULL (sql_mode包含NO_ZERO_DATE)或 0000-00-00 00:00:00 (sql_mode不包含NO_ZERO_DATE)
    2024-06-15 12:09:53
    赞同 1 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
PolarDB+AnalyticDB助力交通物流行业系统升级 立即下载
PolarDB NL2SQL: 帮助您写出准确、优化的SQL 立即下载
云栖大会:开源 PolarDB 架构演进、关键技术与社区建设 立即下载