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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Laravel

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

PHP

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

Q&A

解決済

1回答

2119閲覧

SQLSTATE[HY000]: General error: 1364 エラーによりUser登録ができません

Nt-08

総合スコア1

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Laravel

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

PHP

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

0グッド

0クリップ

投稿2020/10/18 09:07

前提・実現したいこと

初心者です
Laravelを使って個人アプリを作成していますが、userを登録しようとすると
エラーが発生してしまいます。
PHP 7.3.11
SQL 5.6.47

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

Illuminate\Database\QueryException SQLSTATE[HY000]: General error: 1364 Field 'age' doesn't have a default value (SQL: insert into `users` (`name`, `email`, `password`, `role_id`, `updated_at`, `created_at`) values (aaaa, aaaa@aaaa, $2y$10$XsLy8.C7sz5Y0uFMB70pKeGJoz0no.ipt3ARxrK3igABqWW6annJW, 3, 2020-10-17 08:38:51, 2020-10-17 08:38:51))

該当のソースコード

Userphp

1<?php 2 3namespace App; 4 5use Illuminate\Contracts\Auth\MustVerifyEmail; 6use Illuminate\Foundation\Auth\User as Authenticatable; 7use Illuminate\Notifications\Notifiable; 8 9class User extends Authenticatable 10{ 11 use Notifiable; 12 13 /** 14 * The attributes that are mass assignable. 15 * 16 * @var array 17 */ 18 protected $fillable = [ 19 'name', 'email', 'password','role_id','age','e-mail', 20 'image','description' 21 ]; 22 23 /** 24 * The attributes that should be hidden for arrays. 25 * 26 * @var array 27 */ 28 protected $hidden = [ 29 'password', 'remember_token', 30 ]; 31 32 /** 33 * The attributes that should be cast to native types. 34 * 35 * @var array 36 */ 37 protected $casts = [ 38 'email_verified_at' => 'datetime', 39 ]; 40} 41

RegiterController

1<?php 2 3namespace App\Http\Controllers\Auth; 4 5use App\Http\Controllers\Controller; 6use App\Providers\RouteServiceProvider; 7use App\User; 8use App\Role; 9use Illuminate\Foundation\Auth\RegistersUsers; 10use Illuminate\Support\Facades\Hash; 11use Illuminate\Support\Facades\Validator; 12 13class RegisterController extends Controller 14{ 15 /* 16 |-------------------------------------------------------------------------- 17 | Register Controller 18 |-------------------------------------------------------------------------- 19 | 20 | This controller handles the registration of new users as well as their 21 | validation and creation. By default this controller uses a trait to 22 | provide this functionality without requiring any additional code. 23 | 24 */ 25 26 use RegistersUsers; 27 28 /** 29 * Where to redirect users after registration. 30 * 31 * @var string 32 */ 33 protected $redirectTo = RouteServiceProvider::HOME; 34 35 /** 36 * Create a new controller instance. 37 * 38 * @return void 39 */ 40 public function __construct() 41 { 42 $this->middleware('guest'); 43 } 44 45 /** 46 * Get a validator for an incoming registration request. 47 * 48 * @param array $data 49 * @return \Illuminate\Contracts\Validation\Validator 50 */ 51 protected function validator(array $data) 52 { 53 return Validator::make($data, [ 54 'name' => ['required', 'string', 'max:255'], 55 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'], 56 'password' => ['required', 'string', 'min:8', 'confirmed'], 57 ]); 58 } 59 60 /** 61 * Create a new user instance after a valid registration. 62 * 63 * @param array $data 64 * @return \App\User 65 */ 66 protected function create(array $data) 67 { 68 $role= Role::where('name','student')->first(); 69 return User::create([ 70 'name' => $data['name'], 71 'email' => $data['email'], 72 'password' => Hash::make($data['password']), 73 'role_id' => $role->id, 74 'gender' => $data['gender'] 75 ]); 76 } 77} 78 79

試したこと

my.cnfにsql_mode=NO_ENGINE_SUBSTITUTIONを追記してMySQLを再度起動するも
エラー文は変わりませんでした。

補足情報(FW/ツールのバージョンなど)

原因はMySQL5.6からはdefault値がないカラムの情報を追加する場合、カラムの情報を書かない場合は自動で補完されるのではなく、エラーが発生してしまうことまでわかりました。MySQL8.0に変更などしましたがMySQLに接続できなくるなど他にエラーが出まくりで大変だったのでMySQLの更新は断念しました・・・

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

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

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

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

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

sazi

2020/10/18 10:16 編集

エラーの理由は分っていて、8.0に変更する以外の対処方法についての質問ですか?
guest

回答1

0

ベストアンサー

通常、年齢は生年月日と本日日付から算出するので、テーブル上に列として持つことは少ないです。誕生日毎にUPDATEしますし。DEFAULTで値を持つような性格のデータでもないでしょうし。

エラーに関しては、SQLでは文字列や日時データはシングルクォートで囲みます。

SQL

1insert ... 2values (aaaa, aaaa@aaaa, $2y$10$XsLy8.C7sz5Y0uFMB70pKeGJoz0no.ipt3ARxrK3igABqWW6annJW, 3, 2020-10-17 08:38:51, 2020-10-17 08:38:51) 34insert ... 5values ('aaaa', 'aaaa@aaaa', '$2y$10$XsLy8.C7sz5Y0uFMB70pKeGJoz0no.ipt3ARxrK3igABqWW6annJW', 3, '2020-10-17 08:38:51', '2020-10-17 08:38:51') 6

投稿2020/10/18 09:22

編集2020/10/18 09:23
Orlofsky

総合スコア16417

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

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

Nt-08

2020/10/18 10:28

ご回答いただきましてありがとうございます! ageカラムを削除し上記データを挿入したら解決しました 基本的に年齢でのカラムは作成しないということですね! 本当にありがとうございます!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問