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

相关推荐
会编程的土豆10 小时前
GORM 标签详解(数据库字段映射核心)
数据库·gorm
KaMeidebaby10 小时前
卡梅德生物技术快报|真核蛋白表达信号肽筛选实验全流程复盘
服务器·前端·数据库·人工智能·算法
顾凌陵10 小时前
SQL注入漏洞进阶篇
网络·sql
malog_11 小时前
Milvus向量数据库:AI时代的搜索革命
数据库·人工智能·后端·milvus
胡耀超11 小时前
《设计数据密集型应用》(DDIA, 2nd ed.) 心智模型导览——《Designing Data-Intensive Applications》书介绍导航
大数据·数据库·分布式·ai·架构·数据
ai安歌11 小时前
鸿蒙PC:Qt适配OpenHarmony实战【人名录】:单机联系人卡片,不读系统通讯录也能演示详情联动
数据库·qt·harmonyos
夏贰四11 小时前
数据库管理有哪些核心要点?数据库管理该如何规范落地?
大数据·数据库·数据库管理·数据库管理员
彦为君11 小时前
JavaSE-11-ByteBuffer(NIO核心组件)
java·开发语言·前端·数据库·后端·spring·nio
2301_8035389512 小时前
数据分析中count函数怎么用更高效
数据库·oracle
YL2004042612 小时前
【Redis基础篇】Redis常见命令
数据库·redis·缓存