複数のカラムを挿入できない

複数のレコードをカラムに挿入したい

phpのforeach分を使いmysqlのカラムを一括でレコードに挿入させたい

前提

https://kinocolog.com/pdo_prepare_insert/

https://webgroove.work/pdo-prepare-bind-bulk-insert/

のサイトを参考にして実装しましたが下記のようなエラーが出ました

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

Fatal error: Uncaught PDOException: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'name' in 'field list' in C:\xampp\htdocs\players_name\teams.php:102 Stack trace: #0 C:\xampp\htdocs\players_name\teams.php(102): PDOStatement->execute() #1 {main} thrown in C:\xampp\htdocs\players_name\teams.php on line 102

PHP

12 3foreach($plarray as $i => $v) {4 if($i%2==1) {5 $a = array('name' => $v);6 array_push($pl_insert, $a);7 }8}9 10 $pl_insert = [];11 12 $aryColumn = array_keys($pl_insert[0]);13 14 $sql = "INSERT INTO players (".implode(',',$aryColumn).") VALUES"; //・・・①15 16 $sqlarr1 = [];17 18 foreach($pl_insert as $i1 => $v1) {19 $sqlarr2 = [];20 foreach($v1 as $i2 => $v2) {21 $sqlarr2[] = ':' .$i2 . $i1;22 }23 $sqlarr1[] = '('. implode(',',$sqlarr2). ')';24 }25 26 27 $sql .= implode(',', $sqlarr1); 28 29 $stmt = $dbh->prepare($sql); //$dbhがPDO本体30 31 foreach($pl_insert as $key1 => $val1) {32 foreach($val1 as $key2 => $val2) {33 34 $stmt->bindValue(':'.$key2 . $key1 ,$val2);35 }36 }37 38 $stmt -> execute();39

### 試したこと https://inouelog.com/laravel-column-not-found/ を見てnameというカラムが存在しないことだと思い、//・・・①のINSERT INTO players (name)にしてみたりバインドメソッドでは$stmt->bindValue('name',$val2); にしたにして実装しましたが(playersというテーブル名) $stmt -> execute();を実行するとエラーが発生します。 ちなみにvar_dump($sql); でsql文をしらべると string(6049) "INSERT INTO players (name) VALUES(:name0),(:name1),(:name2),(:name3)....となっていたり var_dump($val2)となります。 string(10) "一森 純" string(13) "飯倉 大樹" string(13) "白坂 楓馬" string(32) "オビ パウエル オビンナ" string(13) "永戸 勝也" string(16) "畠中 槙之輔" エラーメッセージを解決できませんよろしくお願いいたします。

コメントを投稿

0 コメント