SQLite をロードする方法はすべて、文字列を使用して名前付きファイルからロードする必要があるようです。SQLite データベースをメモリからロードしたいと思います。
データベースはすでにメモリにロードされています。
特別なファイル名を使用し、:memory:
sqlite3_open(":memory:", &db);
libsqlite
SQLite ドキュメントで指摘されているように、定義せず にコンパイルされている必要があります。SQLITE_OMIT_MEMORYDB
SQLITE_OMIT_MEMORYDB
":memory:"
これが定義されている場合、ライブラリは特別なデータベース名(通常はメモリ内データベースの作成に使用される) を考慮しません。が、、またはに":memory:"
渡されると、この名前のファイルが開かれるか作成されます。sqlite3_open()
sqlite3_open16()
sqlite3_open_v2()
ただし、すでにメモリに完全にロードされているデータベースを読み取りたい場合は、より多くの作業が必要になります。カスタム VFS レイヤーを実装してメモリ ファイルを操作し、それを SQLite コンテキストに登録する必要があります。
見る:
私はそれを自分で実装していないので、新しい VFS レイヤー全体を実装する必要があるのか 、それともデフォルトのものでいくつかの機能を置き換えることができるのかを確実に判断することはできません (後者はありそうにありません)。
にmemvfsの実装があります