【Oracle-无效的参数绑定】DateTimeOffset映射TIMESTAMP WITH LOCAL TIME ZONE踩坑记

背景

我在将Oracle的TimeStampLTZ类型映射到DateTimeOffSet类型时,报了个"无效的参数绑定(Invalid parameter binding (Parameter 'ParameterName"))",堆栈信息如下:

出错原因分析

查阅资料,我知道TimeStampLTZ 和 TimeStampTZ 在技术上都可以映射到 C# 的 DateTimeOffset。经过测试 TimeStampTZ 映射没有问题,TimeStampLTZ映射却报错。

问了AI,怀疑是某些版本的 Oracle ManagedDataAccess 驱动在处理 DateTimeOffset 到 LTZ 的转换时存在 bug,而 TZ 类型不受影响。

两种 Oracle 时间戳类型的本质区别

TIMESTAMP WITH TIME ZONE(TimeStampTZ)

存储的是绝对时间点 + 原始时区信息(时区偏移或区域名)。当您传入一个 DateTimeOffset 时,驱动可以直接将其值(包含日期时间和偏移)存入数据库,读取时也原样返回,几乎不涉及时区转换。因此,绑定过程简单且稳定。

TIMESTAMP WITH LOCAL TIME ZONE(TimeStampLTZ)

存储时会将传入的时间转换为数据库服务器的时区,读取时再转换为当前会话的时区。因此,驱动在处理 DateTimeOffset 参数时,必须进行两步转换:

根据 DateTimeOffset 的偏移,将其转换为绝对时刻(UTC 时间)。

将该绝对时刻转换为数据库服务器的时区(由 DBTIMEZONE 或会话时区决定),然后存储。

如果在这一转换过程中出现任何问题(例如服务器时区设置无效、时区定义缺失、或 DateTimeOffset 的偏移与服务器时区转换规则冲突),就可能导致绑定失败。

解决

AI建议将Oracle ManagedDataAccess 驱动版本升级到最新稳定版(如23.5.0以上)。新版本通常会修复时区转换相关的问题。

经过测试,我将驱动版本升级到最新版本(23.26.100)后,果然成功了。另外测试了版本23.5.0也是成功的。

相关推荐
lzhdim30 分钟前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室1 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)1 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU2 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng3 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿4 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-4 小时前
Redis 命令
数据库·redis·缓存
小江的记录本5 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`5 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存
二宝哥5 小时前
离线安装maven
java·数据库·maven