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

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

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

foreachは、List・Collection・Arrayといったデータ構造の各要素に対して繰り返し処理を実行するために扱われる、制御構造の構文です。

MySQL

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

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

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

Q&A

解決済

1回答

418閲覧

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

irebasunglass

総合スコア8

foreach

foreachは、List・Collection・Arrayといったデータ構造の各要素に対して繰り返し処理を実行するために扱われる、制御構造の構文です。

MySQL

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

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

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

0グッド

0クリップ

投稿2023/09/13 08:48

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

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

1 2 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) "畠中 槙之輔" エラーメッセージを解決できませんよろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

バルクで流し込むときは名前付きprepare処理ではなく疑問符式ににしたほうが楽でしょう

PHP

1$names=["一森 純","飯倉 大樹","白坂 楓馬","オビ パウエル オビンナ","永戸 勝也","畠中 槙之輔"]; 2$sql="INSERT INTO players (name) VALUES"; 3$sql.=implode(",",array_fill(0,count($names),"(?)")); 4$stmt = $pdo->prepare($sql); 5$stmt->execute($names);

参考

SQL

1create table tbl(id int primary key auto_increment ,name varchar(10)); 2insert into tbl(name) values ('aaa'),('bbb'),('ccc');

投稿2023/09/13 09:18

編集2023/09/14 01:17
yambejp

総合スコア117674

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

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

irebasunglass

2023/09/14 01:09

回答ありがとうございます。 やはりカラムが見つかりません しかしながらコードの短縮になりました。 参考になりました。
yambejp

2023/09/14 01:16

それは単純に players テーブルにnameカラムがないのでしょう 参考で追記しておきますが、カラム名が正しければ普通にinsertできると思います
irebasunglass

2023/09/14 02:15

ありがとうございました。 無事に成功いたしました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.31%

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

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

質問する

関連した質問