エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
SQLite3で「database schema has changed」のログが出るとき - やったこと
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
SQLite3で「database schema has changed」のログが出るとき - やったこと
この前自分のサイトにアクセスが急増する出来事があって、そのときにwebサーバに見たことないエラーログ... この前自分のサイトにアクセスが急増する出来事があって、そのときにwebサーバに見たことないエラーログが出力されていた。 下記のような感じのログ。 code:17,database schema has changedこのエラーは、PDOのプリペアドステートメントを使ってデータベース(sqlite3)を更新する箇所で発生していた。 エラー文の意味を英語ブログを読み解きながら調べてみたら、どうも以下のようなことが起きたらしい(日本語ブログには全然説明がなかったぞ!) プリペアドステートメントの機能として、SQL構文のチェックの高速化のためにDBの構造(スキーマ)をキャッシュする、というものがあるらしいんだけど、このキャッシュを利用する際に、もし他のプロセスがDBテーブルの登録・削除処理行って構造(スキーマ)が変わってしまっていた場合、キャッシュが利用できなくなったとみなしてエラーを発生させる、