2016-08-03 102 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