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

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

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

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

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

2回答

1344閲覧

Laravel5のクエリビルダで作成したクエリがSQLエラーで通らない

djdjytr

総合スコア13

MySQL

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

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2017/09/23 00:01

###前提・実現したいこと
Laravel5にて下記のsqlを実行したく、クエリビルダを使い実装しました。

//sql insert into `question` (`question`, `room_mst_id`) values ("てすとです", 1)

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

SQLSTATE[22007]: Invalid datetime format: 1366 Incorrect string value: '\xE3\x81\xA6\xE3\x81\x99...' for column 'question' at row 1 (SQL: insert into `question` (`question`, `room_mst_id`) values ("てすとです", 1))

###該当のソースコード

//クエリビルダ DB::table('question')->insertGetId( [ 'question' => "\"".$question."\"", 'room_mst_id' => $room_id, ] );

###試したこと
実際にNavicatでエラーに出ているSQLをたたいてみると正常にinstertされるのですが、クエリビルダの使い方に間違いがあるでしょうか?
ちなみに英数字だと通ります。
DBの文字コードはutf8mb4となっており、config/database.phpで指定してあるのも同じです。

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

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

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

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

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

guest

回答2

0

エラーメッセージを google 翻訳にかけてみました。

SQLSTATE [22007]:無効な日時形式:1366行1の列 'question'の列の値が '\ xE3 \ x81 \ xA6 \ xE3 \ x81 \ x99 ...'でない(SQL:insert into questionquestion room_mst_id)values( "てすといす"、1))

column 'question' を確認してみてください。

投稿2017/09/23 00:38

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

ベストアンサー

'question' => "\"".$question."\"",
の箇所を
'question' => $question,
に変更してみてください。

Laravelのクエリービルダーは自動的につけてくれます。(正確にはバインドされています)

投稿2017/09/23 00:13

編集2017/09/23 01:06
fagai

総合スコア2158

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

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

djdjytr

2017/09/23 01:06

ご回答ありがとうございます。解決いたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問