C#代码连接Oracle数据库一段时间以后[connection lost contact]的问题

最近在使用C#代码连接Oracle数据库,分为两部分,WCF的客户端与服务端。程序启动与运行都没有问题,部署到服务器上后,运行也没有问题。但是第二天再访问的时候,就会抛出下边所示的异常。这是怎么回事?

  1. Oracle.DataAccess.Client.OracleException ORA-03135: connection lost contact  
  2.     Process ID: 22574  
  3.     Session ID: 799 Serial number: 43225    Oracle.DataAccess.Client.OracleException.HandleErrorHelper(Int32 errCode, OracleConnection conn, IntPtr opsErrCtx, OpoSqlValCtx* pOpoSqlValCtx, Object src, String procedure, Boolean bCheck)  
  4.        at Oracle.DataAccess.Client.OracleCommand.ExecuteReader(Boolean requery, Boolean fillRequest, CommandBehavior behavior)  
  5.        at Oracle.DataAccess.Client.OracleDataAdapter.Fill(DataSet dataSet, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)  
  6.        at System.Data.Common.DbDataAdapter.Fill(DataSet dataSet, String srcTable)  
相关的用于连接Oracle数据库的代码也非常典型,没有一点复杂。

  1. public DataSet ExcuteDataSetForOralce(string sql, CommandType type, List<OracleParameter> paras)  
  2.         {  
  3.             DataSet ds = new DataSet();  
  4.             OracleCommand cmd = null;  
  5.             try  
  6.             {  
  7.                 using (OracleConnection conn = new OracleConnection(ConnectionString))  
  8.                 {  
  9.                     using (cmd = new OracleCommand(sql, conn))  
  10.                     {  
  11.                         if (paras != null)  
  12.                         {  
  13.                             foreach (OracleParameter p in paras)  
  14.                             {  
  15.                                 cmd.Parameters.Add(p);  
  16.                             }  
  17.                         }  
  18.                         cmd.CommandType = type;  
  19.                         OracleDataAdapter oda = new OracleDataAdapter();  
  20.                         oda.SelectCommand = cmd;  
  21.                         conn.Open();  
  22.                         oda.Fill(ds, "tempTable");  
  23.                         conn.Close();  
  24.                     }  
  25.                 }  
  26.             }  
  27.             catch (Exception ex)  
  28.             {  
  29.                 log.Error("error", ex, LogType.Error);  
  30.             }  
  31.             return ds;  
  32.         }  

通过多方查找,发现这并不是代码的问题。而且Provider与数据库连接的问题。实际上,我们new一个连接的时候,是从数据库连接池里边拿到的连接,这些连接放在.NET Provider里边。Conn.Close()并不是关闭了连接,而是把连接还给了连接池。

 

现在的问题是Oracle Provider的问题,而不是代码的问题。你的程序很久没有跟数据库交互了,数据库服务器端就把连接的Open状态关了,但是Provider没有及时处理,依然给了C#代码用,所以就抛出了这个异常。

 

解决办法就是,不使用连接池,每次直接连数据库,虽然不会出现这个问题,但是会有性能上的损失。

 

在app.config的配置文件中,在DataSource=((Description...)这个字符串中,加入不使用连接池。

Data  Source =( DESCRIPTION =( ADDRESS_LIST =( ADDRESS =( PROTOCOL = TCP )( HOST = xxx )( PORT = 1521 )))(CONNECT_DATA =( SERVICE_NAME = xxx )(SERVER = DEDICATED)));User  ID = xxx ; password = xxxxx ; Pooling = false
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值