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

相关推荐
rgeshfgreh14 小时前
Python连接KingbaseES数据库全指南
开发语言·数据库·python
小北方城市网14 小时前
数据库性能优化实战指南:从索引到架构,根治性能瓶颈
数据结构·数据库·人工智能·性能优化·架构·哈希算法·散列表
TDengine (老段)14 小时前
TDengine Go 语言连接器进阶指南
大数据·数据库·物联网·golang·时序数据库·tdengine·涛思数据
何中应14 小时前
使用Spring自带的缓存注解维护数据一致性
java·数据库·spring boot·后端·spring·缓存
ZeroToOneDev14 小时前
Mybatis
java·数据库·mybatis
野犬寒鸦14 小时前
从零起步学习RabbitMQ || 第一章:认识消息队列及项目实战中的技术选型
java·数据库·后端
枫叶丹414 小时前
【Qt开发】Qt系统(六)-> Qt 线程安全
c语言·开发语言·数据库·c++·qt·安全
HalvmånEver14 小时前
Linux:深入剖析 System V IPC上(进程间通信八)
linux·运维·数据库·c++·system v·管道pipe
brevity_souls14 小时前
SQL 中“过滤条件”写在 SELECT、JOIN 和 WHERE 的区别
数据库·sql
麦聪聊数据15 小时前
拒绝循环写库:MySQL 批量插入、Upsert 与跨表更新的高效写法
数据库·sql·mysql