SQLite での断続的なテーブル欠落エラー: メモリ: データベース
php エディタ Banana は、SQLite における断続的なテーブル損失エラーの解決策を提供します。 SQLite データベースを使用すると、メモリ エラーやテーブルの損失が発生する可能性があります。このエラーは通常、不適切なデータベース操作またはメモリの問題によって発生します。この問題を解決するには、クエリ ステートメントの最適化、メモリ制限の増加などの対策を講じることができます。この記事では、データベースが適切に動作するように、この問題のトラブルシューティングと解決方法を詳しく説明します。
質問内容
Goではgithub.com/mattn/go-sqlite3 v1.14.16経由でSQLite 3.39.4を使用しています。接続文字列は ":memory:?cache=shared&mode=rwc&_mutex=no&_journal=WAL&_sync=NORMAL"
テスト中に「そのようなテーブルはありません: 構成」というエラーが発生することがあります。混乱を招くのは、問題のクエリがテスト ケースで正常に使用され、その後データベース接続とエラーをスローするトランザクション オブジェクトの両方で sqlite_master へのクエリにテーブルが表示されることです。ただし、エラーが発生すると、クエリは成功しなくなります。
これがかなり漠然とした質問であることは承知していますが、誰かが少なくともどこを見るべきかを提案してもらえますか?データベース接続は常に同じポインタ値を持ちます。
更新:
2 回目の試行で、ほぼこの SSCCE の問題を再現できました:
リーリー showTables は SSCCE ではテーブルを表示しませんが、実際のテストでは表示するため、実際の問題とは異なります。この例は、トランザクションがクローズされていない場合に限り、example.db
の代わりに :memory:
を使用する場合の問題を示しています。これはインメモリ データベースの既知の動作ですか、それとも予期される動作ですか?
解決策
Go database/sql
接続プールを暗黙的に使用しますが、:memory:
データベースはデフォルトで接続を開きますprivate 。
参照してください: https://www.php.cn/link/d346256ad566cf97801e5cecc45a2557
複数の SQLite 接続がバックグラウンドで作成または閉じられるため、どの接続が各ステートメントを実行し、どのデータベースに対して実行しているのかは実際にはわかりません。そのため、一部の接続では特定のデータが表示され、他の接続では表示できないのは当然のことです。 。
接続を共有する 1 つの方法は、あなたが試しているように、cache=shared
を使用することです。ただし、SQLite では、これを URI として指定する必要があります: file::memory:?cache=shared
(file:
は重要です)。
共有メモリ データベースを開くためのより信頼性の高い方法は次のとおりです:
-
file:memdb1?mode=memory&cache=shared
(名前はmemdb1
) -
file:/memdb1?vfs=memdb
(名前は/memdb1
、memdb
VFS を使用)
他のパラメータは、(メモリ内データベースの場合) 不要であるか、有害である可能性さえあります。
以上がSQLite での断続的なテーブル欠落エラー: メモリ: データベースの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









OpenSSLは、安全な通信で広く使用されているオープンソースライブラリとして、暗号化アルゴリズム、キー、証明書管理機能を提供します。ただし、その歴史的バージョンにはいくつかの既知のセキュリティの脆弱性があり、その一部は非常に有害です。この記事では、Debian SystemsのOpenSSLの共通の脆弱性と対応測定に焦点を当てます。 Debianopensslの既知の脆弱性:OpenSSLは、次のようないくつかの深刻な脆弱性を経験しています。攻撃者は、この脆弱性を、暗号化キーなどを含む、サーバー上の不正な読み取りの敏感な情報に使用できます。

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

この記事では、GOでテーブル駆動型のテストを使用して説明します。これは、テストのテーブルを使用して複数の入力と結果を持つ関数をテストする方法です。読みやすさの向上、重複の減少、スケーラビリティ、一貫性、および

この記事では、コードのランタイム操作に使用されるGoの反射パッケージについて説明します。シリアル化、一般的なプログラミングなどに有益です。実行やメモリの使用量の増加、賢明な使用と最高のアドバイスなどのパフォーマンスコストについて警告します

この記事では、go.modを介してGOモジュールの依存関係の管理、仕様、更新、競合解決をカバーすることについて説明します。セマンティックバージョンや定期的な更新などのベストプラクティスを強調しています。

バックエンド学習パス:フロントエンドからバックエンドへの探査の旅は、フロントエンド開発から変わるバックエンド初心者として、すでにNodeJSの基盤を持っています...
