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

Oracle.DataAccess.Client.OracleException ORA-: connection lost contact
Process ID:
Session ID: Serial number: Oracle.DataAccess.Client.OracleException.HandleErrorHelper(Int32 errCode, OracleConnection conn, IntPtr opsErrCtx, OpoSqlValCtx* pOpoSqlValCtx, Object src, String procedure, Boolean bCheck)
at Oracle.DataAccess.Client.OracleCommand.ExecuteReader(Boolean requery, Boolean fillRequest, CommandBehavior behavior)
at Oracle.DataAccess.Client.OracleDataAdapter.Fill(DataSet dataSet, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.Fill(DataSet dataSet, String srcTable)

相关的用于连接Oracle数据库的代码也非常典型,没有一点复杂。

public DataSet ExcuteDataSetForOralce(string sql, CommandType type, List<OracleParameter> paras)
{
DataSet ds = new DataSet();
OracleCommand cmd = null;
try
{
using (OracleConnection conn = new OracleConnection(ConnectionString))
{
using (cmd = new OracleCommand(sql, conn))
{
if (paras != null)
{
foreach (OracleParameter p in paras)
{
cmd.Parameters.Add(p);
}
}
cmd.CommandType = type;
OracleDataAdapter oda = new OracleDataAdapter();
oda.SelectCommand = cmd;
conn.Open();
oda.Fill(ds, "tempTable");
conn.Close();
}
}
}
catch (Exception ex)
{
log.Error("error", ex, LogType.Error);
}
return ds;
}

通过多方查找,发现这并不是代码的问题。而且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=)))(CONNECT_DATA =(SERVICE_NAME=xxx)(SERVER = DEDICATED)));User ID=xxx;password=xxxxx;Pooling=false;

最新文章

  1. c# 九九乘法表
  2. hihocoder-1453-Rikka with Tree
  3. mysql performance_schema/information_schema授权问题
  4. 让show parameter显示隐含参数(12C)
  5. websphere变成英文了
  6. 启用Win8(中文版/核心版)中被阉割的远程桌面服务端
  7. Scala学习笔记--特质trait
  8. Hadoop-2.7.1集群环境搭建
  9. javaScript中获取鼠标位置的理解
  10. Spring随笔 - 事务隔离级别
  11. Spire.XLS for .NET 測评
  12. 解决AES算法CBC模式加密字符串后再解密出现乱码问题
  13. MySQL面试题中:主从同步部署介绍
  14. 行为驱动开发(BDD) - 深入了解
  15. 集合总结三(HashMap的实现原理)
  16. Alpha冲刺随笔五:第五天
  17. Codeforces.547D.Mike and Fish(思路 欧拉回路)
  18. MVC单元测试,使用Repository模式、Ninject、Moq
  19. “全栈2019”Java第二十五章:流程控制语句中循环语句while
  20. 【Codeforces629C】Famil Door and Brackets [DP]

热门文章

  1. 5213 Exp3 免杀原理与实践
  2. MVVM Light Toolkit使用指南
  3. 【最详细最完整】在Linux 下如何打包免安装的QT程序?
  4. 【HNOI2016】矿区
  5. 使用 spring-boot-devtools 进行热部署
  6. ElasticSearch入门 第八篇:存储
  7. [Mark]Tomcat/IIS 更改 HTTP 侦听端口
  8. 移动端三合一瀑布流插件(原生JS)
  9. Html_div圆角
  10. GitHub 新手教程 二,Windows 版 GitHub 安装