zoukankan      html  css  js  c++  java
  • C#代码连接Oracle数据库一段时间以后[connection lost contact]的问题

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

     

    Oracle.DataAccess.Client.OracleException ORA-03135: connection lost contact
        Process ID: 22574
        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)
           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=1521)))(CONNECT_DATA =(SERVICE_NAME=xxx)(SERVER = DEDICATED)));User ID=xxx;password=xxxxx;Pooling=false;

     

  • 相关阅读:
    pdf .js和tableexport.js使用时遇到的2问题。
    一个基础的问题 多个$(function(){})里面的函数 为什么在下一个$(function(){})里没法执行。
    关于emoji表情,支持在app端发送web端显示,web端发送给app端显示,web与wap端互相显示。
    $.isEmptyObject() 判断对象是否为空
    Access数据库参数没值
    C#导入EXCEL数据
    [IE兼容性] Table 之边框 (IE6 IE7 IE8(Q) 中 cellspacing 属性在重合的边框模型的表格中仍然有效)
    META标签的NAME变量
    控制台应用程序中Main函数的args参数
    无法为表空间 ***中的段创建 INITIAL 区
  • 原文地址:https://www.cnblogs.com/hnsongbiao/p/7417021.html
Copyright © 2011-2022 走看看