は、Web APIは、我々は、クエリORACLEDBを作成し、レコードの巨大なセットを返し、私たちはJSON以下データ-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;
問題は、300,000のような膨大な数の行があり、メモリ不足例外をスローする場合です。私は他のフォーラムで、この問題がページネーションによって解決できることを読んだ。しかし、クライアントアプリケーションはWeb APIが呼び出されたときに完全な結果を必要とするため、一度にレコードのセット全体を取得しようとしています。私はどのようにこれを処理するか分からない。どんな助けでも大歓迎です。
あなたのRAM容量はいくらですか? – MRebati
このアプリケーションはWindowsサーバーで実行されます2012 – user4912134
Windows server 2012は操作システムです。 RAMはランダムアクセスメモリである。これらは2つの異なるものです。アプリケーションによってメモリ例外が発生します。私はあなたの記憶容量がどれくらいあるか知りたいですか? – MRebati