Laravel・エックスサーバーエラー:json型利用時にNotice in ./libraries/dbi/DBIMysqli.class.phpと出た時の対策

Laravelデータベース

エックスサーバーでjson型を利用しているとき、下記のようなエラーが出たときの対策です。

Some errors has been detected on the server!
Notice in ./libraries/dbi/DBIMysqli.class.php#523
 Undefined offset: 245

ひとことでいうと、json型をlongtext型に変えましょう。

Laravel・エックスサーバーエラー:json型利用時にNotice in ./libraries/dbi/DBIMysqli.class.phpと出た時の対策

以下、わたしが経験した例でお伝えしていきますね。

わたしの場合は、チェックボックス用のデータ型として、マイグレーションファイルにjson型を指定していました。

ローカル環境では、このjson型は自動でlongtext型に変換されていました。

エックスサーバーにプロジェクトを反映させたところ、エックスサーバーでは、無事、該当カラムのデータ型はjson型になっていました。

ですが、実際にデータをいれると、こんなふうにエラーぎっしりになってしまいまいました。

Junko
Junko

一瞬どきっとしますね。

そこで検証した結果、どうやらデータ型が怪しいと気づきまして。該当のマイグレーションファイルをロールバックしました。

そのあと、マイグレーションファイルのデータ型をlongtextに変更しました。

【修正前のマイグレーションファイルから抜粋】

【修正後のマイグレーションファイルから抜粋】

こうするとエラーが修正できました。

Junko
Junko

同じようなエラーに悩む人の参考になれば嬉しいです。

なお、もし記事で紹介した状況と異なる前提条件ですと、お伝えした方法ではエラーが解決しない可能性もあります。

Laravelデータベース Laravel・PHP豆知識・トラブル対策

【Laravelの教科書・プレゼント】

Junko
Laravelの使い方を覚えたい!と思ったら、ぜひ、役立ててほしいです。 基礎編は無料でプレゼント中です♪
ひつじプログラマ
会員制サイトをいちから作っていくよ。ボタンをクリックして詳細を見てね。
Laravelの教科書の詳細を見る

Laravel8版と、最新のLaravel9版、ふたつのテキストご用意してます♪

【無料プレゼント】

「LaravelでWebアプリをいちから作れるようになりたい!」

そんなLaravel初心者のあなたへ【Laravelの教科書】基礎編プレゼント中! 会員制フォーラムサイトを学習しながら作れます。

詳細はこちらをクリック

Laravel8版と、最新のLaravel9版、ふたつのテキストご用意してます♪

Laravel関連のご相談承ってます♪
「Webアプリを開発してほしい」
「社内にLaravelが分かる人がいない。コンサルしてほしい」
そんな企業様のご依頼承っています。
お問い合わせはこちら
Laravel関連のご相談承ってます♪
「Webアプリを開発してほしい」
「社内にLaravelが分かる人がいない。コンサルしてほしい」
そんな企業様のご依頼承っています。
お問い合わせはこちら
Twitter始めました。
40代からプログラミング!

コメント

タイトルとURLをコピーしました