2016-11-01 910 views
3

私のコードで断続的にこのエラーが発生しています。時間が経つにつれて時々起こることがあります。時には10回のうちに1回発生することもあります。私は、COPYコマンドを実行していたStackOverflow上の他のポスターとは異なり、私のSQLではユニークで特別なことはしていません。私がやっていることはすべてSELECTです。ここで ストリームからの読み取り中にNpgsql例外、Postgres

は、スタックトレースです:

Exception while reading from stream 
at Npgsql.ReadBuffer.Ensure(Int32 count, Boolean dontBreakOnTimeouts) 
at Npgsql.NpgsqlConnector.DoReadMessage(DataRowLoadingMode dataRowLoadingMode, Boolean isPrependedMessage) 
at Npgsql.NpgsqlConnector.ReadMessageWithPrepended(DataRowLoadingMode dataRow LoadingMode) 
at Npgsql.NpgsqlConnector.ReadMessage(DataRowLoadingMode dataRowLoadingMode) 
at Npgsql.NpgsqlConnector.ReadExpecting[T]() 
at Npgsql.NpgsqlDataReader.NextResultInternal() 
at Npgsql.NpgsqlDataReader.NextResult() 
at Npgsql.NpgsqlCommand.Execute(CommandBehavior behavior) 
at Npgsql.NpgsqlCommand.ExecuteDbDataReaderInternal(CommandBehavior behavior) 
at Npgsql.NpgsqlCommand.ExecuteDbDataReader(CommandBehavior behavior) 
at System.Data.Common.DbCommand.ExecuteReader() 
at Npgsql.NpgsqlCommand.ExecuteReader() 
at JBetaFinder.Program.portfolioSimulation(String beginResult, String endResult) in c:\Users\j\Documents\Visual Studio 2013\Projects\JBetaFinder\JBetaFinder\Program.cs:line 571 

このエラーを回避する方法上の任意の提案?これはNpgsqlとpostgresの問題ですか?ここで

が最も問題であるように思わ私のSQL文です:

select leg1.trade_date, sum(p.qty) as totalqty, max(gas.net_change)*10000 as avggaschange, 
      sum(((leg1.settlement_price - leg2.settlement_price) - (leg3.settlement_price - leg4.settlement_price))*qty*1000000) as spread_value_weight 
      from quant_portfolio p 
      inner join (select distinct trade_date, hub, product, strip, settlement_price, net_change 
          from public.icecleared_gas where contract = 'H') leg1 
          on p.leg1 = leg1.strip 
      inner join (select distinct trade_date, hub, product, strip, settlement_price, net_change 
          from public.icecleared_gas where contract = 'H') leg2 
          on p.leg2 = leg2.strip and leg1.trade_date = leg2.trade_date     
      inner join (select distinct trade_date, hub, product, strip, settlement_price, net_change 
          from public.icecleared_gas where contract = 'H') leg3 
          on p.leg3 = leg3.strip and leg1.trade_date = leg3.trade_date     
      inner join (select distinct trade_date, hub, product, strip, settlement_price, net_change 
          from public.icecleared_gas where contract = 'H') leg4 
          on p.leg4 = leg4.strip and leg1.trade_date = leg4.trade_date 
      inner join (select distinct trade_date, hub, product, strip, contract, settlement_price, net_change 
          from public.icecleared_gas where contract = 'H') gas 
          on gas.strip = (select min(leg1) from quant_portfolio where commodity = 'NG') and gas.trade_date = leg1.trade_date       
      where p.commodity = 'NG' 
      AND (leg1.trade_date>='xxx' and leg1.trade_date<='yyy') 
      group by leg1.trade_date 
      order by leg1.trade_date 

私は副問い合わせを取り出し、それらすべてが参加するようにする再配置SQLみました。助けにもならなかった、同じエラー。ここで

はNpgsqlの呼び出しC#コードです:;ユーザーID = postgresの;パスワード= somepw;データベース= somedb;

query = new NpgsqlCommand(getFullQuantPortBeta.ToString().Replace("xxx", beginResult.ToString()).Replace("yyy", endResult.ToString()), conn); 
      dr = query.ExecuteReader();//code does not get past this line! 
      beta = 0; 
      while (dr.Read()) 
      { 
       baselineData.Add(double.Parse(dr[2].ToString())); 
       responseData.Add(double.Parse(dr[3].ToString())); 
       if (baselineData.Count > 3) 
       { 
        Tuple<double, double> result = MathNet.Numerics.LinearRegression.SimpleRegression.Fit(baselineData.ToArray(), responseData.ToArray()); 
        beta = result.Item2 * BETA_MULT; 
        Console.WriteLine("WEIGHT BETA = " + beta); 
       } 
      } 
      dr.Close(); 
+0

ようこそスタックオーバーフローへようこそNpgsqlを呼び出す場所にC#を投稿できますか? –

+0

例外レポートは不完全です。例外のタイプや内部例外(実際の問​​題が含まれている可能性があります)は投稿しません。あなたの質問にそれらを追加してください。 –

答えて

2

でCONN =新しいNpgsqlConnectionを( "サーバー= myserverのプール= falseは、タイムアウト= 300; CommandTimeout = 300 ");

接続文字列にCommandTimeoutプロパティを追加しましたが、現在は動作しているようです。タイムアウトエラーの奇妙な例外...

関連する問題