gpt4 book ai didi

c# - 分页 Web API 返回的大量数据

转载 作者:可可西里 更新时间:2023-11-01 09:06:08 26 4
gpt4 key购买 nike

我们创建了用于查询 Oracle 数据库的 WebAPI。查询返回的结果很大,因此有时会抛出 OutOfMemoryException

建议使用分页 概念。我不明白客户端应用程序如何知道必须调用 API 多少次才能获得整组结果。我还需要为分页创建一个单独的类,还是可以在我的 API Controller 中操作它。

谁能帮我解决这个问题,因为这是我的第一个 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;
}
}
}
}

最佳答案

通过 API 进行分页的总体思路是,客户端将传递他们想要的数据“页面”和他们想要的记录“数量”。

从那里您可以构造您的查询以达到以下效果

选择所有记录,但跳过 ((Page - 1) * amount) 条记录并取 (amount) 条记录。

如果您使用 LINQ to SQL,则有 Take() 和 Skip() 方法可以帮助您更轻松地在代码端编写代码。如果您不使用 LINQ to SQL,则需要查找特定于 Oracle 的内容。

最后要注意的是,由于一个好的 API 被设计为“无状态”,因此客户端需要在处理上一页/下一页查询时维护他们所在的页面。通常,页面和数量变量保存在 Javascript 中,甚至像隐藏变量一样简单,可用于计算有多少页面可用等

这是我进行的用于分页的 WebAPI 调用的基本示例。如果 LINQ to SQL/EF 不支持它,您可能需要稍微修改它以支持获取所有记录和可能的任何 Oracle 特定内容:

public IActionResult GetProducts(int? page, int? count)
{
var takePage = page ?? 1;
var takeCount = count ?? DefaultPageRecordCount;

var calls = context.Products
.Skip((takePage - 1) * takeCount)
.Take(takeCount)
.ToList();

return Json(calls);
}

关于c# - 分页 Web API 返回的大量数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38752848/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com