SQL 错误 [22007]: ERROR: invalid input syntax for type date: ““

0. 背景

PG数据库一张表有这样一个varchar类型的字段end_date,存储的值是格式化后的年月日日期如 2024-08-10

现在我需要根据当前日期与end_date的差值作为where条件过滤,我的写法

sql 复制代码
select ......
from my_table_name
where current_date - cast (end_date as date) >=100

报错

Caused by: org.postgresql.util.PSQLException: ERROR: invalid input syntax for type date: ""

1. 原因

这个错误翻译:

无效的类型date的输入语法:""

"" 代表end_date 字段中存在空字符串(""),显然它不能正确地转换为date类型!!!

我们group by end_date 发现,该字段的确存在不正确的value ,如

空字符串""/字母N,具体参考下图

2. 解决

根据业务需求,我只需要取正确的日期即可:用正则仅匹配正确格式的日期进行过滤即可

sql 复制代码
select ......
from my_table_name
where 
end_date ~'^\d{4}-\d{2}-\d{2}$'
AND
current_date - cast (end_date as date) >=100

2.1 PG正则相关

正则操作符

~:用于进行正则表达式匹配。

~*:类似于 ~,但是进行不区分大小写的正则匹配。

!~:用于进行正则表达式不匹配。

!~*:类似于 !~,但是进行不区分大小写的正则不匹配。
正则表达式约束

^: 串开头的匹配

$:串结尾的匹配

其他就是常见的正则知识了:\d表示数字...

相关推荐
XDHCOM4 分钟前
ORA-41722权限不足引发数据库变更通知故障,Oracle报错修复与远程处理方案引热议
数据库·oracle
修己xj7 分钟前
人大金仓 KingbaseES V8 数据库 Docker 部署指南
数据库
Yushan Bai23 分钟前
windows环境oracle 11.2.0.1版本数据库启动报错ORA-01589问题的处理
数据库·oracle
予早25 分钟前
Redis 设置库的数量
数据库·redis·缓存
奔跑吧树袋熊38 分钟前
Oracle 9i 与 19c 跨版本字符集乱码(US7ASCII ↔ AL32UTF8)DBLink 解决方案
数据库·oracle
byzh_rc43 分钟前
[AI编程从入门到入土] 配置文件
java·数据库·ai编程
oradh1 小时前
Oracle数据库模式、对象的入门概述
数据库·oracle·oracle数据库基础
雷工笔记1 小时前
SQL语句解析:DESC LIMIT 1
数据库·sql
城数派1 小时前
2025年全国地级市间驾车出行距离和出行时间矩阵数据
数据库·arcgis·信息可视化·数据分析
wgzrmlrm741 小时前
SQL实现按用户偏好进行分组汇总_自定义聚合规则
jvm·数据库·python