ASP.NET连接Oracle的四个常见问题

开发 后端
本文向您介绍ASP.NET连接Oracle数据库的四个常见问题,包括协议适配器错误、VS.NET链接Oracle时报错等。

ASP.NET连接Oracle问题1:System.Exception: System.Data.OracleClient requires Oracle client software version 8.1.7 or greater

原因:NTFS权限问题,在ORACLE9I时总是遇到

解决方法:

1、以管理员的用户登录;

2、找到ORACLE_HOME文件夹(我的是C:\oracle\ora92),点右键,选属性--安全,在组或用户栏中选“Authenticated Users”,在下面权限列表中把“读取和运行”的权限去掉,再按应用;重新选上“读取和运行”权限,点击应用;选权限框下面的“高级”按钮,确认“Authenticated Users”后面的应用于是“该文件夹、子文件夹及文件”,按确定把权限的更改应用于该文件夹;

3、重新启动计算机,让权限设置生效(请注意,这一步很重要);

4、登录后运行asp.net应用,正常取得Oracle数据库的数据。

ASP.NET连接Oracle问题2:ORA-12560: TNS: 协议适配器错误

解决方法:

①.检查Terminal Service, 远程桌面是不是起因

②.环境变量set oracle_sid=需要的服务名

③.listener.ora, tnsnames.ora等内机器名或者IP地址是否正确

④.netstat -a检查端口是否被占用

⑤.检查注册表HKEY_LOCAL_MACHINE\Software\Oracle\Home0新增字符串USE_SHARED_SOCKET =True

ASP.NET连接Oracle问题3:ORA-12571、ORA-03113、ORA-03114、ORA-01041

特征:客户端(代理或应用服务器)有时报这类断连错误

原因:如果偶尔出现一次,则可能为网络原因或用户异常中止,如果经常出现则为客户端与服务端的字符集不一致。

措施:如果偶尔出现,可在服务端的协议配置文件PROTOCOL.ORA中增加一行TCP.NODELAY=YES;

如果经常出现,则为客户端与服务端字符集不一致或网络原因。

客户端的字符集在注册表里定义:       

HKEY__LOCAL__MACHINE/SOFTWARE/ORACLE/NLS__LANG

在客户端注册表中的TCP参数项中设置:   

TCPMAXDATARETRANSMITIONS=20。

ASP.NET连接Oracle问题4:使用VS.NET链接Oracle时报错

ORA-03114: not connected to Oracle

解决方法:

在打了下面的补丁后,问题依旧:

FIX: A pooled connection is not disposed by Microsoft .NET Managed Provider for Oracle when an exception occurs

http://support.microsoft.com/default.aspx?scid=kb;en-us;830173

产生该原因是ADO.NET将一个无效的Oracle连接放回了连接池,当下一次使用时就会产生问题。所以解决方法是禁用连接池。禁用连接池的方法是在连接字符串中将pooling 设为false。

最后,通过禁用连接池并在每次session开始的时候关闭连接然后重新建立解决了问题。

问题由于oracle重启或者连接中断而ADO.Net仍然未释放连接所致,解决方法是通过禁用OracleClient的Pooling,禁用方法是在连接字符串中加上Pooling=false.

另外,据了解,Sql Server重启也会引起Asp.Net类似的问题,如果使用SqlClient,也可以用同样的方法禁用Pooling.若是OLEDB的连接方式,则在连接字符串中加上OLE DB Services=-4;来禁用Connection Pool.

【编辑推荐】

  1. ASP.NET 2.0教程 数据源控件解析
  2. 在ASP.NET中向数据库批量插入数据
  3. ASP.NET用Post方式向网页发送数据
  4. ASP.NET 2.0部署WEB应用程序浅析
  5. ASP.NET中的HttpWorkerRequest对像
  6. 介绍ASP.NET MVC框架
责任编辑:冰荷 来源: yesky
相关推荐

2009-07-20 14:32:08

2009-07-30 12:30:27

ASP.NET中使用S

2009-04-01 16:46:31

问题开发WebService

2012-06-12 09:37:26

2009-07-29 15:26:43

ASP.NET连接Or

2011-08-01 23:34:34

ASP.NETOracle

2010-04-23 09:58:30

Oracle管理

2009-08-06 15:56:40

ASP.NET Coo

2009-09-22 09:22:03

.NET常见问题

2010-04-14 14:37:56

Oracle卸载

2011-01-26 11:09:07

2022-10-26 14:55:53

AIoT物联网人工智能

2010-04-28 11:09:47

Oracle常见问题

2009-08-25 17:42:41

ASP.NET新手问题

2010-04-27 18:24:56

Oracle常见问题

2009-07-29 11:18:21

ASP.NET连接My

2011-07-12 16:07:42

OracleToad环境变量

2009-07-23 10:08:24

asp.net mvc

2009-04-27 10:33:16

ASP.NET视图状态

2009-07-22 17:45:35

ASP.NET教程
点赞
收藏

51CTO技术栈公众号