.NET 4 C# コンソール アプリケーションがあります。IBM i からデータを取得し、インターネット SQL Server に送信します。終了するまで完璧に動作しますが、次のエラーが発生します。
System.ObjectDisposedException は処理されませんでした メッセージ = 安全なハンドルが閉じられました Source=mscorlib ObjectName="" StackTrace: System.Runtime.InteropServices.SafeHandle.DangerousRelease() で System.Threading.RegisteredWaitHandleSafe.Finalize() InnerException:
私のプログラムコードは次のとおりです。
class Program
{
static void Main(string[] args)
{
System.Console.WriteLine("Begin: " + DateTime.Now.ToString());
SystemCodeController sc = new SystemCodeController();
sc.SyncSystemCodes();
ParkingTicketController pt = new ParkingTicketController();
pt.SyncParkingTickets();
EmailHelper.SendSuccessEmail();
System.Console.WriteLine("End: " + DateTime.Now.ToString());
}
}
コンソールに、開始時刻と終了時刻が表示されます。したがって、最終行が実行されることはわかっています。私は何を忘れているのか、何をしていないのか?
更新: Sync* メソッドは、IBM からオブジェクトにデータをプルし、エンティティ フレームワークを使用してレコードをデータベースに挿入します。
public void SyncParkingTickets()
{
ptr.ClearTable();
ptr.InsertNewCitation(ibmI.GetAllCitations());
ptr.SaveChanges();
}
public void InsertNewCitation(IEnumerable<ParkingTicket> citations)
{
foreach (ParkingTicket citation in citations)
{
InsertNewCitation(citation);
}
}
public void InsertNewCitation(ParkingTicket citation)
{
db.AddToParkingTickets(citation);
}
public IEnumerable<ParkingTicket> GetAllCitations()
{
SystemCodeRepository scr = new SystemCodeRepository();
// Create SQL statement
DataTable dt = new DataTable();
using (iDB2Connection conn = new iDB2Connection(_connString))
{
using (iDB2Command cmd = new iDB2Command(sb.ToString(), conn))
{
conn.Open();
using (iDB2DataAdapter da = new iDB2DataAdapter(cmd)) { da.Fill(dt); }
conn.Close();
}
}
#region Fill object from DataTable
var citations = from i in dt.AsEnumerable()
select new ParkingTicket
{
// Fill object
};
#endregion
return citations;
}
すべてのメソッドは、これと同様に機能します。