记一次sqlserver连接Oracle

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了记一次sqlserver连接Oracle相关的知识,希望对你有一定的参考价值。

参考技术A

由于要和第三方系统集成。我方(Oracle)提供视图。直接让对方(Sqlserver)读取。
我方建立好试图后,通过客户端工具可以查询。就没有管。对方一直说报错。而且对方排查了好久。说有些表是可以查的,说让我方也帮忙排查一下。
具体报错: 链接服务器 "KING" 的 OLE DB 访问接口 "OraOLEDB.Oracle" 为列提供的元数据不一致。对象 ""KD210911"."V_COUNTING"" 的列 "PLANDATE" (编译时序号为 3)在编译时有 0 的 "DBCOLUMNFLAGS_ISNULLABLE",但在运行时有 32。

由于我不太熟悉sqlserver以及他们那边的是如何具体操作的。我先说下我的思路,以及最后如何解决此问题。
1.确实先进行了百度。OpenQuery()是别人提供的一些解决。而我们没成功。
2.我们排除了权限问题。因为有些表是可以查询的。
3.等到第二天的时候,我在他们电脑上进行了调试。回归最开始的报错,PLANDATE确实是视图里边的列。说明已经到视图这里了。
4.我就想着把PLANDATE这一列先在视图里边去掉。看看报什么错。不出意外。又报了其他列的错误。这时报错的这一列也是时间格式。心中大喜,难道是因为时间格式对方解析不了。就把所有时间列去掉了。就成功了。
5.后边把时间列都进行了转换为字符串。成功解决。

记一次 Oracle无法连接 问题分析

前言

今天,同事告诉我,有台Oracle服务器异常断电,重启后发现无法连接了。

分析过程

1.检查服务状态

查看Oracle的listerner服务和service服务,发现都是正在运行状态,说明服务是正常的。

2.检查端口状态

在客户机上使用:

tnsping 服务器IP:1521

返回OK,说明端口也是正常的。

3.检查日志

检查Oracle安装目录下的所有log文件,最后在“D:\\app\\Administrator\\product\\11.2.0\\dbhome_1\\database\\oradim.log”下发现如下内容:

D:\\app\\Administrator\\product\\11.2.0\\dbhome_1\\bin\\oradim.exe -startup -sid orcl -usrpwd * -log oradim.log -nocheck 0

ORA-00119: invalid specification for system parameter LOCAL_LISTENER 

ORA-00132: syntax error or unresolved network name 'LISTENER_ORCL'

感觉找到错误根源了。

4.检查数据库启动状态

于是,在服务器上验证数据库是否启动成功,运行下列命令:

sqlplus / as sysdba
SQL>startup

返回如下错误:

可以确定了,启动参数有问题,导致数据库并未启动成功!

解决方法

由于我们没有改过任何参数,而Oracle默认使用spfile启动,因此先尝试使用pfile启动:

SQL>startup pfile='D:\\app\\Administrator\\orcl\\pfile\\init.ora.1223201617822

pfile和spfile的区别请自行百度

发现启动成功,并且客户端可以正常连接了。

于是怀疑是spfile文件损坏,使用下列命令重建spfile:

SQL> create spfile from pfile;

重启服务后,一切恢复正常!

结论

刚开始陷入了经验误区,认为服务启动了数据库就是正常工作的,导致走了一些弯路。

如果你觉得这篇文章对你有所启发,请关注我的个人公众号”My IO“

以上是关于记一次sqlserver连接Oracle的主要内容,如果未能解决你的问题,请参考以下文章

SQLServer记一次数据迁移-标识重复的简单处理

记一次SQLServer的分页优化兼谈谈使用Row_Number()分页存在的问题

记一次SQL环境搭建

记一次机器socket连接数持续增长的问题

记一次 .NET 某游戏网站 CPU爆高分析

记一次优化的的意外收获