Oracleデータベースからバルク・データを戻すasp.net Web APIサービス・エンドポイントを作成しています。返されたデータをJSON形式で変換しています。それは罰金働いていたが、突然、私は、文字列の結果でメモリ不足の例外というエラーを取得していますか、それは、ネットワーク・セッションを示している:私は、実行時に予期しないパケット読み取りエラーをメモリ不足例外またはOracle Unexceptedパケット読み取りエラー
public HttpResponseMessage Getdetails([FromUri] string[] id)
{
using (OracleConnection dbconn = new OracleConnection("DATA SOURCE=J;PASSWORD=C;PERSIST SECURITY INFO=True;USER ID=T"))
{
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 + ")";
OracleCommand selectCommand = new OracleCommand(strQuery, dbconn);
OracleDataAdapter adapter = new OracleDataAdapter(selectCommand);
DataTable selectResults = new DataTable();
adapter.Fill(selectResults);
string result = JsonConvert.SerializeObject(selectResults);
string contentDisposition = "inline; filename=ProvantisStudyData.json";
//byte[] byteInfo = Encoding.ASCII.GetBytes(result);
HttpResponseMessage response = Request.CreateResponse(HttpStatusCode.OK, result, MediaTypeHeaderValue.Parse("application/json"));
response.Content.Headers.ContentDisposition = ContentDispositionHeaderValue.Parse(contentDisposition);
//response.Content.Headers.ContentLength = byteInfo.Length;
return response;
}
}
しかし、 Oracle DB内の同じクエリは直接データを返します。それは50,000以上のレコードを返します。エラーは一貫性がなく、結果を返すことがあり、同じフィルターでOut of memory例外またはOracle Unexceptedパケット読み取りエラーを返すことがあります。
これは、ネットワークを介してスラッグするデータの多くです。それがなぜ「突然」起こるのか、時には起こるのかはわかりません。私の推測はネットワークに関連するでしょう。人々が面白い猫のビデオを見ているとき、あなたは問題を抱えています。 –
これは突然発生し、ときどきうまくいくことがあります。 – trx