【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也是成功的。

相关推荐
Full Stack Developme20 分钟前
MySQL 触发器 存储过程 介绍
数据库·mysql
杨云龙UP28 分钟前
MySQL慢查询日志暴涨导致磁盘告警:slow query log膨胀至397G的生产故障排查:清理、参数优化
linux·运维·服务器·数据库·mysql
Bat U39 分钟前
MySQL数据库|视图+索引
数据库·mysql
SQVIoMPLe1 小时前
[拆解LangChain执行引擎]以Actor模型的视角来看Pregel
服务器·数据库·langchain
你都会上树?1 小时前
Ubuntu22 安装PostgreSQL
数据库·postgresql
想唱rap2 小时前
线程之条件变量和生产消费模型
java·服务器·开发语言·数据库·mysql·ubuntu
RInk7oBjo2 小时前
MySQL的编译安装
数据库·mysql·adb
java资料站2 小时前
MySQL 增量同步脚本
android·数据库·mysql
ningmengjing_2 小时前
从零推导出 Redis
数据库·redis
IvorySQL2 小时前
PostgreSQL & IvorySQL 技术交流 Meetup・郑州站| 4.18 线下开讲,只聊硬核技术
数据库·postgresql·开源