2016-08-03 101 views
1

在Web API,我們創建查詢OracleDB的,並返回一個巨大的記錄集,我們將不得不把它轉換到JSON處理大量的數據 - 織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

你的內存容量是多少? – MRebati

+0

此應用程序在Windows服務器上運行2012 – user4912134

+0

Windows服務器2012是一個操作系統。 RAM是隨機存取存儲器。這是兩件不同的事情。該應用程序給你內存異常。我想知道你的內存容量有多少? – 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