ADO.NETの質問・雑談スレ2 (421レス)
上
下
前
次
1-
新
413
(3)
: [age] 2020/10/29(木)19:13 ID:???
AA×
外部リンク:okwave.jp
外部リンク:social.msdn.microsoft.com
[240|
320
|
480
|
600
|
原寸
|
JPG
|
べ
|
レス栞
|
レス消
]
413: [age] 2020/10/29(木) 19:13:13.83 ID:??? 質問すみません。 環境: - OS: Windows 10 (バージョン 2004, ビルド 19041.572) - Visual Studio: Visual Studio 2019 Community (Version 16.7.6) - ターゲット Framework: .NET Framework 4.0/4.7.2 - Driver: Microsoft Access Driver (*.mdb, *.accdb) 16.00.4999.1000 (Access 2016 Redist) コード概要: デーモンとして待ち受け、要求に応じてDB(主に Access accdb データベース)のデータを返すプログラムです。 現象: ADODB.Connection をインスタンス化した connection を Open するとき、実行開始後初回〜数回は正常に値を取得できますが、数分時間をおいた後、再度 connection を Open すると、AccessViolationException が発生します: ``` ハンドルされていない例外: System.AccessViolationException: '保護されているメモリに読み取りまたは書き込み操作を行おうとしました。他のメモリが壊れていることが考えられます。' ``` 現状: - デーモンのコンソールには、正常時には、結果が表示されますが、異常時(今回の現象)では「致命的なエラーです。」と表示されます: ``` 致命的なエラーです。 ハンドルされていない例外: System.AccessViolationException: 保護されているメモリに読み取りまたは書き込み操作を行おうとしました。他のメモリが壊れていることが考えられます。 場所 ADODB.ConnectionClass.Open(String ConnectionString, String UserID, String Password, Int32 Options) 場所 Project1.Class1.Get(String[] fields, NameValueCollection nameValueCollection) 場所 C:\Users\mona\source\repos\Project1\Project1\Class1.cs:行 196 ``` - "AccessViolation|fatal ado.net|adodb connection open" 等で Google 検索すると、Close 漏れだとかの指摘がありますが、Close は必ずしています。(finally 節で connection.Close() しています) <https://okwave.jp/qa/q3428421.html> - netsh winsock reset で改善したという事例 <https://social.msdn.microsoft.com/Forums/vstudio/en-US/9e41e16b-27b2-40e3-8b6c-83930103e7b8/attempted-to-read-or-write-protected-memory-on-any-sql-connection-open-after-installing-net?forum=netfxbcl> がありましたので試しましたが改善しません。 - Provider=Microsoft.ACE.OLEDB.16.0;Data Source=C:\Users\mona\Documents\db.accdb;Persist Security Info=False; のような接続文字列の代わりにODBCデータソースでシステムDSNを定義し、DSN=db を指定しても改善しません。 - Visual Studio を管理者権限で実行しても改善しません。 - 試しにコネクションを毎回新規作成していますが改善しません。 英語サイト等も見ましたが先行事例がなかなか見つからず苦慮しています。せめてヒントでもありましたらご教示いただければ幸いです。よろしくお願いいたします。 http://mevius.5ch.net/test/read.cgi/db/1234077152/413
質問すみません 環境 バージョン ビルド ターゲット コード概要 デーモンとして待ち受け要求に応じて主に データベースのデータを返すプログラムです 現象 をインスタンス化した を するとき実行開始後初回数回は正常に値を取得できますが数分時間をおいた後再度 を すると が発生します ハンドルされていない例外 保護されているメモリに読み取りまたは書き込み操作を行おうとしました他のメモリが壊れていることが考えられます 現状 デーモンのコンソールには正常時には結果が表示されますが異常時今回の現象では致命的なエラーですと表示されます 致命的なエラーです ハンドルされていない例外 保護されているメモリに読み取りまたは書き込み操作を行おうとしました他のメモリが壊れていることが考えられます 場所 場所 場所 行 等で 検索すると 漏れだとかの指摘がありますが は必ずしています 節で しています で改善したという事例 がありましたので試しましたが改善しません のような接続文字列の代わりにデータソースでシステムを定義し を指定しても改善しません を管理者権限で実行しても改善しません 試しにコネクションを毎回新規作成していますが改善しません 英語サイト等も見ましたが先行事例がなかなか見つからず苦慮していますせめてヒントでもありましたらご教示いただければ幸いですよろしくお願いいたします
上
下
前
次
1-
新
書
関
写
板
覧
索
設
栞
歴
あと 8 レスあります
スレ情報
赤レス抽出
画像レス抽出
歴の未読スレ
AAサムネイル
ぬこの手
ぬこTOP
0.052s