質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

3回答

1581閲覧

Laravel Seederを使用してデータベースへ登録したい

TKHS8203

総合スコア3

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2021/05/14 08:00

編集2021/05/14 10:53

前提・実現したいこと

ローカル環境のHomestead内で
Laravel 7のSeederを使用してデータベースへ登録ができるようにしようと思っています。

$php artisan migrate:fresh --seed を実行したところ以下のエラーメッセージが発生しました。

実現したいこと

データベースに登録したデータをcontrollerを通してviewに渡し、scheduleの値を表示させるため、
該当のソースコード内にある schedule の値をデータベースへ登録したいです。 
よろしくお願いいたします。

発生している問題・エラーメッセージ

Seeding: SpotestSeeder ErrorException Array to string conversion at vendor/laravel/framework/src/Illuminate/Support/Str.php:488 484| 485| $result = array_shift($segments); 486| 487| foreach ($segments as $segment) { > 488| $result .= (array_shift($replace) ?? $search).$segment; 489| } 490| 491| return $result; 492| } +8 vendor frames 9 database/seeds/SpotestSeeder.php:26 Illuminate\Database\Query\Builder::insert() +7 vendor frames 17 database/seeds/DatabaseSeeder.php:18 Illuminate\Database\Seeder::call()

該当のソースコード

SpotestSeeder.php

1use Illuminate\Database\Seeder; 2use App\Model\Spotest; 3 4class SpotestSeeder extends Seeder 5{ 6 /** 7 * Run the database seeds. 8 * 9 * @return void 10 */ 11 public function run() 12 { 13 DB::table('spotests')->delete(); 14 DB::table('spotests')->insert([ 15 [ 16 'id' => '1', 17 'name' => 'namae01', 18 'schedule' => [ 19 '2021-05' => ['10:00','0','0','0','0','0','0'] 20 ], 21 'created_at' => new DateTime(), 22 'updated_at' => new DateTime(), 23 ] 24 ]); 25 } 26}

2021_05_10**_create_spotests_table.php

1use Illuminate\Database\Migrations\Migration; 2use Illuminate\Database\Schema\Blueprint; 3use Illuminate\Support\Facades\Schema; 4 5class CreateSpotestsTable extends Migration 6{ 7 /** 8 * Run the migrations. 9 * 10 * @return void 11 */ 12 public function up() 13 { 14 Schema::create('spotests', function (Blueprint $table) { 15 $table->id(); 16 $table->text('name'); 17 $table->json('schedule'); 18 $table->timestamps(); 19 }); 20 } 21 22 /** 23 * Reverse the migrations. 24 * 25 * @return void 26 */ 27 public function down() 28 { 29 Schema::dropIfExists('spotests'); 30 } 31}

試したこと

エラーには Array to string conversion と出ているので、'schedule'の配列を文字列に変換できない事かと思い、
database > migrations > 2021_05_10******_create_spotests_table.php 内のカラム型を変更してみましたが
エラーは変わらず Array to string conversion と表示されています。

補足情報

Laravel Framework 7.30.4
mysql Ver 8.0.23-0
ubuntu0.20.04.1 for Linux on x86_64 ((Ubuntu))

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

SpotestSeeder.phpのscheduleをjson_encode()に修正したところ、Seederからデータベースへ登録が成功し、意図した通りの値を取得できるようになりました。
※database > migrations > 2021_05_10**_create_spotests_table.php 内のカラム 型も $table->json('schedule');へ変更済み。

SpotestSeeder.php

1 [ 2 'id' => '1', 3 'name' => 'namae01', 4 'schedule' => json_encode([ 5 '2021-05' => ['10:00','0','0','0','0','0','0'] 6 ]), 7 'created_at' => new DateTime(), 8 'updated_at' => new DateTime(), 9 ]

回答してくださったucan-lab様、TakashiAbe様、ありがとうございました!

投稿2021/05/14 11:03

TKHS8203

総合スコア3

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

'schedule' => [ '2021-05' => ['10:00','0','0','0','0','0','0'] ],

schedule に渡す値を文字列型にしてデータを挿入してみてください。
カラムの型が日付型であれば、DateTime型やCarbon型にして挿入してみてください。

データベース周りの質問を行う際は spotests のテーブル構成も提示いただけるとより精度の高い回答が得られると思います。

また、Laravelでシーダーを作る場合モデルファクトリーを利用すると便利です。

https://readouble.com/laravel/7.x/ja/database-testing.html#generating-factories

投稿2021/05/14 09:33

ucan-lab

総合スコア888

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

TKHS8203

2021/05/14 10:54

ucan-lab様、ご回答いただき有難うございます。 質問時、情報を揃えることができずすみません。spotests のテーブル構成 追記させていただきました。 モデルファクトリーの情報も有難うございます。 併せて上記も確認させていただきます!
guest

0

ベストアンサー

DBのscheduleカラムがどうなってるかの情報がありませんが、配列をそのままデータベースの中に入れたいということですか? であればシリアライズして入れればいいと思います。

'schedule' => serialize([ '2021-05' => ['10:00','0','0','0','0','0','0'] ]),

もちろん、データを引っ張ってきたときは最初にunserialize()で戻す必要があります。

質問の意図が違っていたらごめんなさいですが、そうであればたぶん私以外の人にも伝わらないと思いますので、もう少し伝わるように質問文を更新・追記してください。

投稿2021/05/14 09:29

AbeTakashi

総合スコア4580

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

TKHS8203

2021/05/14 10:54

TakashiAbe様、ご回答いただき有難うございます。 serialize() を入れたところ無事に Database seeding completed successfully.となりました。 DBから取り出す際のunserialize()も案内していただきありがとうございます。 serializenoを検索中、別の方法としてjson_encodeを使用するパターンもあり、そちらで試したところスムーズに配列を取り出すことが出来ました。 ヒントを頂きありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問