DEVELOPERS BLOGデベロッパーズブログ
- HOME >
- 加藤 正人のデベロッパーズブログ >
- CakePHP3 と SQLite
加藤 正人のデベロッパーズブログ
- 氏名
- 加藤 正人
- 役職
- 多分SE
- 血液型
- 秘密
- 出没
- 美味しいもののあるところ
- 特色
- タヒチ大好き。ちょいメタボ。
- 2020/12/15
- CakePHP3 のリダイレクトがうまく行かない例
- 2020/11/12
- Apache Bench
- 2020/10/05
- PhpSpreadsheet でExcel ファイルを読み込む (CakePHP3)
PHP 5.x 以降には、SQLite というデータベースがバンドルされている。CakePHP には SQLite 用のドライバが標準添付されており、簡単に利用できる。
今回は CakePHP 3 で SQLite を使用する方法を調べてみた。
SQLite の特徴
- パブリックドメインなデータベースエンジンであり、ライセンス料などが不要。公式サイトはこちら。
- メモリーとファイルシステムを利用してアプリケーションとして実装され、データベースサーバが不要。
- ファイルシステムを使用せず、メモリー内のみでの実装が可能 (「メモリー内データベース (In-Memory データベース)」)
- 「認証」という概念がない。
CakePHP 3 から SQLite を利用する
CakePHP 3 から SQLite を利用する場合は、 Datasources セクションの定義、Table 定義時のコネクション設定、および Table 初期設定などが必要となる。
Datasources セクションの定義
config/app.php の 'Datasources' セクション ('Datasources' => [ …【中略】… ] として定義) に、以下のコードを追加する。
これにより 'SQLite' というデータソース名が定義される。(他のデータソース定義と重複しなければ別の名称でも可。)
なお、'database' 項に指定できるのは「ファイル名」のみで、URI 記法は利用できない。これは CakePHP 3 の SQLite ドライバーの制限である。このため、接続パラメータやデータベースオプションをファイル名に埋め込む方法は利用できない。またパスやサブフォルダをつけない純粋な ':memory:' はファイル名として予約されており、この文字列を指定した場合はデータベースはメモリー内にのみ配置されファイルは使用しない。(パスなどを付加した、例えば './:memory:’ 等はメモリー内データベースファイル指定とは認識されず、ファイルとして処理しようとする点に注意)
テーブル定義
SQLite を使用するテーブルの定義で、データソースとして 'SQLite' を指定する。CakePHP 3 ではプロパティではなく、データソース名文字列を返す静的メソッドで定義する。これにより、テーブルオブジェクト生成時に 'SQLite' データソースを使用することを明示できる。
なお、テーブルデータベースの実体は通常はデータソースの 'database' 項で指定した単一のファイルに格納され永続的なものになるが、':memory:' でメモリー内データベースを指定した場合はデータベースは当該データベースへの接続がクローズされると直ちに破棄される。また、同じメモリー内データベースに接続できるのは、同一プロセス内で生成された接続に限られる点に注意。
関連エントリー
- 2020/12/15
- CakePHP3 のリダイレクトがうまく行かない例
- 2020/10/05
- PhpSpreadsheet でExcel ファイルを読み込む (CakePHP3)
- 2020/08/03
- CakePHP3 のユーザー定義ファインダーのオプション
- 2020/05/07
- CakePHP3 で JSON 応答のための定番処理
- 2020/04/02
- CakePHP3 でタイムゾーン変換
- 2020/02/01
- バージョンを指定して CakePHP をインストールする
- 2020/01/03
- CakePHP サイトの移転時の注意
- 2019/12/07
- CakePHP3 のアソシエーションで、紐づけ用フィールドを指定する
- 2019/11/07
- CakePHP3 のコマンドライン実行
- 2019/09/02
- CakePHP3 の Virtual Field と accessor (Getter)
- 2019/07/04
- CSRF token mismatch
- 2019/01/07
- CakePHP3 で "Could not send email: unknown"
- 2018/12/03
- CakePHP3 の JSON 出力でエラー
- 2018/10/01
- CakePHP3 のミューテータで書き換えたデータが保存されない件
- 2018/08/01
- CakePHP3.6.2 のタイムスタンプ調整 (XSERVER の場合)
- 2018/07/04
- CakePHP3 で DebugKit が表示されない
- 2018/05/01
- 最新版 composer.phar のインストール
- 2018/03/06
- PHP 7.x で CakePHP 3.x を使う
- 2017/11/10
- Remi's PHP5.6 と intl モジュール
- 2017/05/23
- X2 と CakePHP 3.x
- 2017/03/03
- CakePHP3 の便利機能
- 2017/01/20
- CakePHP3 でテーブル不使用フォームのバリデーション
- 2016/12/10
- CakePHP3 のファインダーメソッド
- 2016/09/10
- CakePHP 3.x の accessor と mutator 【その2】
- 2016/09/03
- CakePHP 3.x の accessor と mutator
- 2016/08/06
- XSERVER X10 に CakePHP 3.x をインストールする
- 2016/04/09
- XSERVER で CakePHP 3.x が Fatal error
- 2015/09/12
- CakePHP 3.x インストールメモ
- 2015/06/13
- Composer メモ
2020/12/15
2020/11/12
2020/10/05
2020/09/11
2020/08/03