2016-08-03 11 views
1

は、Web APIは、我々は、クエリORACLEDBを作成し、レコードの巨大なセットを返し、私たちはJSON以下データ-WebのAPIを大量に処理

にしてそれを変換する必要があります実際のコントローラコード

です
public HttpResponseMessage Getdetails([FromUri] string[] id) 
{ 
string connStr = ConfigurationManager.ConnectionStrings["ProDataConnection"].ConnectionString; 
using (OracleConnection dbconn = new OracleConnection(connStr)) 
{ 
    var inconditions = id.Distinct().ToArray(); 
    var srtcon = string.Join(",", inconditions); 
    DataSet userDataset = new DataSet(); 
    var strQuery = @"SELECT * from STCD_PRIO_CATEGORY where STPR_STUDY.STD_REF IN(" + srtcon + ")"; 
    using (OracleCommand selectCommand = new OracleCommand(strQuery, dbconn)) 
    { 
     using (OracleDataAdapter adapter = new OracleDataAdapter(selectCommand)) 
     { 
      DataTable selectResults = new DataTable(); 
      adapter.Fill(selectResults); 
      var returnObject = new { data = selectResults }; 
      var response = Request.CreateResponse(HttpStatusCode.OK, returnObject, MediaTypeHeaderValue.Parse("application/json")); 
      ContentDispositionHeaderValue contentDisposition = null; 
      if (ContentDispositionHeaderValue.TryParse("inline; filename=ProvantisStudyData.json", out contentDisposition)) 
      { 
       response.Content.Headers.ContentDisposition = contentDisposition; 
      } 
      return response; 

問題は、300,000のような膨大な数の行があり、メモリ不足例外をスローする場合です。私は他のフォーラムで、この問題がページネーションによって解決できることを読んだ。しかし、クライアントアプリケーションはWeb APIが呼び出されたときに完全な結果を必要とするため、一度にレコードのセット全体を取得しようとしています。私はどのようにこれを処理するか分からない。どんな助けでも大歓迎です。

+0

あなたのRAM容量はいくらですか? – MRebati

+0

このアプリケーションはWindowsサーバーで実行されます2012 – user4912134

+0

Windows server 2012は操作システムです。 RAMはランダムアクセスメモリである。これらは2つの異なるものです。アプリケーションによってメモリ例外が発生します。私はあなたの記憶容量がどれくらいあるか知りたいですか? – MRebati

答えて

1

私は同様の問題を持っていたし、私のweb.configファイルにいくつかのパラメータを追加することによってそれを解決:

<requestLimits maxAllowedContentLength="2147483647" /> 

(これは<system.webServer><security><requestFiltering>の内部に配置されている)

<httpRuntime targetFramework="4.6.1" maxRequestLength="2147483647" executionTimeout="1600" requestLengthDiskThreshold="2147483647" /> 

(これはセクション<system.web>にある必要があります)

+0

ありがとうRobert、タグはweb.configに存在しませんでした。私はそれらを手動で追加しました。私は再びアプリケーションを実行しようとしましたが、それは長い間ロードを続けます。結果を少し早く返す時間を改善する機会はありますか? – user4912134

+0

それは若者に永遠にかかって、再びメモリの例外例外を投げている – user4912134

+0

私がテストしたIDは633060行を返すはずです。しかし、このエラーがスローされます。アプリケーションにブレークポイントを追加しました。 – user4912134

関連する問題