处理大量数据-Web API
本文关键字:-Web API 数据 处理 | 更新日期: 2023-09-27 18:00:07
我们创建的Web API查询OracleDB并返回大量记录,我们必须将其转换为JSON
以下是实际的控制器代码
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;
问题是,如果我们有像300000这样的大量行,就会抛出内存不足异常。我在其他论坛上读到,这个问题可以通过分页来解决。但我希望一次获得整个记录集,因为当调用Web API时,客户端应用程序需要整个结果。我不知道该怎么处理。任何帮助都将不胜感激。
我遇到了类似的问题,并通过在我的web.config:中添加一些参数来解决
<requestLimits maxAllowedContentLength="2147483647" />
(放置在<system.webServer><security><requestFiltering>
内)
和
<httpRuntime targetFramework="4.6.1" maxRequestLength="2147483647" executionTimeout="1600" requestLengthDiskThreshold="2147483647" />
(必须在<system.web>
部分中)