背景全文及翻译

背景

Oracle数据向MySQL同步,没有最新数据,于是在plsql手敲SQL筛选最新数据时,执行报错。

问题描述

通过日期字段筛选最近的数据,我用了类似这样的语句:

mysql 复制代码
SELECT *
FROM orders
WHERE order_date > '2022/01/01';

我信心满满按下F8,plsql给我报了这么个错误(或者是英文,同义):

复制代码
Oracle SQL错误:ORA-01861:文字与格式字符串不匹配

原因分析

开始的时候我以为日期中间的分隔符它不识别,然而换了什么符号都不行。

搜了一下,看到这篇博客

,文中提到在插入、筛选时间字段时都会有这个问题(更新应该也有),格式不匹配。

要注意到这里我们写的看着是个日期,但实际上在Oracle看来,这只是个字符串,并不能和日期格式的数据作比较。

只有日期格式相互之间才能比较。利用Oracle的TO_DATE函数,可将字符串转为日期/时间类型,这是Oracle之TO_DATE函数的详细用法

解决方案

使用TO_DATE,SQL如下:

sql 复制代码
SELECT *
FROM orders
WHERE order_date > TO_DATE('2022/01/01', 'YYYY/MM/DD');

声明:本文使用八爪鱼rpa工具从gitee自动搬运本人原创(或摘录,会备注出处)博客,如版式错乱请评论私信,如情况紧急或久未回复请致邮 xkm.0jiejie0@qq.com 并备注原委;引用本人笔记的链接正常情况下均可访问,如打不开请查看该链接末尾的笔记标题(右击链接文本,点击 复制链接地址,在文本编辑工具粘贴查看,也可在搜索框粘贴后直接编辑然后搜索),在本人博客手动搜索该标题即可;如遇任何问题,或有更佳方案,欢迎与我沟通!

相关推荐
杨云龙UP4 小时前
Oracle RAC/ODA环境下如何准确查询PDB表空间已分配大小?一次说清Oracle表空间逻辑大小和ASM三副本实际占用_2026-05-19
linux·运维·数据库·sql·oracle·ffmpeg
Cloud_Shy6186 小时前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第十一章 Python 包跟踪器 中篇)
数据库·python·sql·数据分析·excel·web
Gauss松鼠会10 小时前
【GaussDB】基于SpringBoot实现操作GaussDB(DWS)的项目实战
java·数据库·经验分享·spring boot·后端·sql·gaussdb
想唱rap11 小时前
IO多路转接Select
运维·服务器·网络·数据库·sql·tcp/ip·mysql
Yushan Bai11 小时前
ORACLE SQL Performance Analyzer (SPA) 测试流程
数据库·sql
JavaEdge.12 小时前
07-LangChain Toolkit 实战:从工具函数到 Python Agent,再到 SQL Agent
python·sql·langchain
历程里程碑13 小时前
53 多路转接select
linux·开发语言·数据结构·数据库·c++·sql·排序算法
山峰哥1 天前
SQL慢查询调优实战:从全表扫描到索引覆盖的完整复盘
前端·数据库·sql·性能优化
hhb_6181 天前
PL/SQL核心技术难点梳理与实战应用案例解析
数据库·sql
TDengine (老段)1 天前
TDengine 一条 SQL 从客户端到执行完成的全链路
大数据·数据库·sql·物联网·时序数据库·tdengine·涛思数据