$encryption_key and all encryption features will be enabled only if the SQLite encryption module is installed. It's a proprietary, costly module. So if it's not present, supplying an encryption key will have absolutely no effect.
(PHP 5 >= 5.3.0, PHP 7, PHP 8)
SQLite3::__construct — SQLite3 オブジェクトを作成し、SQLite 3 データベースをオープンする
$filename
, int $flags
= SQLITE3_OPEN_READWRITE | SQLITE3_OPEN_CREATE, string $encryptionKey
= "")SQLite3 オブジェクトを作成し、SQLite 3 データベースをオープンします。 暗号化込みでビルドされている場合は、キーの使用を試みます。
filename
SQLite データベースへのパス。インメモリデータベースを使う場合は :memory:
を指定します。
filename
に空文字列を指定すると、
プライベート、かつ一時的なデータベースがディスク上に作成されます。
このプライベートなデータベースは、データベース接続が閉じられるとすぐに自動的に削除されます。
flags
SQLite データベースのオープン方法を指定するフラグ。
デフォルトでは SQLITE3_OPEN_READWRITE | SQLITE3_OPEN_CREATE
を使用してオープンします。
SQLITE3_OPEN_READONLY
:
データベースを読み込み専用でオープンする
SQLITE3_OPEN_READWRITE
:
データベースを読み書き共用でオープンする
SQLITE3_OPEN_CREATE
:
データベースが存在しない場合は作成する
encryptionKey
オプションの暗号キー。SQLite データベースの暗号化と復号に使用します。 暗号化モジュールがインストールされていない場合は、このパラメータは何の影響も及ぼしません。
失敗した場合に Exception をスローします。
バージョン | 説明 |
---|---|
7.0.10 |
filename は、空文字列を指定できるようになりました。
この場合、プライベート、かつ一時的なデータベースがディスク上に作成されます。
|
例1 SQLite3::__construct() の例
<?php
$db = new SQLite3('mysqlitedb.db');
$db->exec('CREATE TABLE foo (bar TEXT)');
$db->exec("INSERT INTO foo (bar) VALUES ('This is a test')");
$result = $db->query('SELECT bar FROM foo');
var_dump($result->fetchArray());
?>
$encryption_key and all encryption features will be enabled only if the SQLite encryption module is installed. It's a proprietary, costly module. So if it's not present, supplying an encryption key will have absolutely no effect.
Note that the SQLITE3_OPEN_READONLY flag cannot be combined with the SQLITE3_OPEN_CREATE flag. If you combine both of these flags, a rather unhelpful "Unable to open database: out of memory" exception will be thrown.