在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時需要整個結果。我不知道我將如何處理這個問題。任何幫助是極大的讚賞。
你的內存容量是多少? – MRebati
此應用程序在Windows服務器上運行2012 – user4912134
Windows服務器2012是一個操作系統。 RAM是隨機存取存儲器。這是兩件不同的事情。該應用程序給你內存異常。我想知道你的內存容量有多少? – MRebati