解决Oracle异常ORA-01861:literal does not match format string(字符串格式不匹配)

在VC的应用程序中通过ADO操作oracle数据库(老实说我其实也不懂什么ADO,OLEDB,ODBC之间到底是个什么鸟关系),在数据同步语句中,update date型的语句没有使用to_date函数,应用返回错误:Description: [Oracle][ODBC][Ora]ORA-01861 :literal does not match format string.

我知道这是没有指定日期字符串格式的原因,但是可以通过设定默认格式解决,否则每次操作date型的数据还都要to_date,真是烦死了.

因为是客户端程序报的错,我便再环境变量中设置了NLS_DATE_FORMAT,sqlplus和第三方的客户端都可以省略to_date了,但是应用程序还是报错.

无奈,网上搜索很多literal does not match format string的解决方法,也尝试了修改注册表,加入NLS_DATE_FORMAT,仍旧不行.

我就奇了怪了,这个环境变量和注册表你都不吃,应用程序你究竟是要闹哪出?这到底是ODBC还是OLEDB还是ADO哪一层不知道这个默认日期格式呢?

就在我绝望之际,想到数据库服务端还有相关参数设置,但是我始终不认为是服务端的问题,因为在客户端sqlplus已经起作用,而且to_date的事情应该是客户端去做吧.

去服务端检查了参数show parameter nls_date_format,value是空的,试着修改了这个参数,果然应用也不报错了.我想这个参数的作用就是,如果客户端那边什么都不说,就按照这个格式去处理日期的数据吧.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值