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表示数字...

相关推荐
键盘上的猫头鹰44 分钟前
【MySQL 教程(八)】索引、事务、用户管理、导入导出与分页查询
数据库·python·mysql
Royzst44 分钟前
数据库知识点
数据库
雪的季节1 小时前
企业级 Qt 全功能项目
开发语言·数据库·qt
宋浮檀s1 小时前
应急响应——Web漏洞:命令执行+SSRF+弱口令
运维·数据库·sql·网络安全·oracle·应急响应
yurenpai(27届找实习中)3 小时前
redis_点评(21.好友关注——关注、取关功能实现;共同关注功能实现)
数据库·redis·缓存
Rick19933 小时前
索引的排序和分组
数据库·mysql
爱莉希雅&&&3 小时前
zabbix快速搭建和使用
android·linux·数据库·zabbix·监控
JohnYan3 小时前
工作笔记 - PG分组极值
数据库·后端·postgresql
清溪5493 小时前
DataEase H2 JDBC-RCE(CVE-2025-32966)复现
数据库·安全
ServBay3 小时前
不要再盲选了,PostgreSQL、MySQL与SQLite真实性能对比
数据库·mysql·sqlite