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

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

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

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

Laravel

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

PHP

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

Q&A

解決済

2回答

427閲覧

Laravel php foreachでループ処理が上手くいかない

yoheiiii

総合スコア87

foreach

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

Laravel

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

PHP

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

0グッド

0クリップ

投稿2023/04/18 02:40

編集2023/04/18 03:42

実現したいこと

foreachでループ処理をして該当のものだけDBに保存したい。

前提

$targetには下記の様に入っています。

array ( 0 => array ( 0 => '1', 1 => '110', 2 => '12345', 3 => '23456', 4 => '2020/4/1', 5 => '2020/4/1', 6 => '1', 7 => '1111', 8 => 'テストエラー', 9 => '', 10 => '', 11 => '', 12 => '', 13 => '', 14 => '', 15 => '', 16 => '', 17 => '', 18 => '', 19 => '', 20 => '', 21 => '', 22 => '', 23 => '', 24 => '', 25 => '', ), 1 => array ( 0 => '3', 1 => 'yk123456', 2 => 'ky123456', 3 => '222222', 4 => '100000', 5 => '3333444455556666', 6 => '1125', 7 => '10', 8 => '', 9 => '', 10 => '12', 11 => 'yy12345', 12 => '', 13 => 'kk123456', 14 => '987654', 15 => '0', 16 => '', 17 => '1', 18 => '1111', 19 => 'エラーテスト', 20 => '0', 21 => '50001', 22 => '株式会社田中', 23 => '55555', 24 => 'yyk1', 25 => 'y01234', ), 2 => array ( 0 => '3', 1 => 'yk234567', 2 => 'ky234567', 3 => '333333', 4 => '100000', 5 => '4444555566667777', 6 => '1125', 7 => '10', 8 => '', 9 => '', 10 => '12', 11 => 'yy23456', 12 => '', 13 => 'kk234567', 14 => '876543', 15 => '0', 16 => '', 17 => '1', 18 => '2222', 19 => 'エラーテスト', 20 => '0', 21 => '50001', 22 => '株式会社田中', 23 => '66666', 24 => 'yyk2', 25 => 'y43210', ), 3 => array ( 0 => '4', 1 => '400', 2 => '200', 3 => '100', 4 => '', 5 => '', 6 => '', 7 => '', 8 => '', 9 => '', 10 => '', 11 => '', 12 => '', 13 => '', 14 => '', 15 => '', 16 => '', 17 => '', 18 => '', 19 => '', 20 => '', 21 => '', 22 => '', 23 => '', 24 => '', 25 => '', ), )

0 => の値が1と4の時にデータをDBに保存したい。

該当のソースコード

foreach($target as $val){ $data = new aaa(); if($val[0] === '1'){ $inputdata = $val[0].",".$val[0].",".$val[1].",".$val[2].",".$val[3].",".$val[4].",".$val[5].",".$val[6].",".$val[7]; $data->RecordId = $val[0]; $data->Note = $inputdata; $data->save(); } if($val[0] === '4'){ $inputdata = $val[0].",".$val[0].",".$val[1].",".$val[2].",".$val[3]; $data->RecordId = $val[0]; $data->Note = $inputdata; $data->save(); } }
<?php namespace App; use Illuminate\Database\Eloquent\Model; class aaa extends Model { protected $table ="datarecord"; }

現状、DBは下記のように保存されてしまいます。
イメージ説明

試したこと

foreach($target as $key => $val){ $data = new dr_ricella(); if($val[$key][0] === '1'){ $inputdata = $val[0].",".$val[0].",".$val[1].",".$val[2].",".$val[3].",".$val[4].",".$val[5].",".$val[6].",".$val[7]; $data->RecordId = $val[0]; $data->Note = $inputdata; $data->save(); } if($val[$key][0] === '4'){ $inputdata = $val[0].",".$val[0].",".$val[1].",".$val[2].",".$val[3]; $data->RecordId = $val[0]; $data->Note = $inputdata; $data->save(); } }

keyをつけてやってみたのですが、結果からみて4の場合も1の処理になってしまっています。
イメージ説明

【バージョン情報】
Laravel Framework 6.20.44
PHP 7.2.34

ご教授頂けないでしょうか。
宜しくお願い致します。

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

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

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

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

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

m.ts10806

2023/04/18 02:58

aaaというクラスの実装はどうなってるのでしょう
m.ts10806

2023/04/18 03:00

また配列の提示はvar_export()で変数出力したものを貼り付けてください。現状だと手元での確認が非常に手間です
yoheiiii

2023/04/18 03:12

aaaの部分とvar_export()で出力し編集致しました。 宜しくお願い致します。
m.ts10806

2023/04/18 03:33

Laravelですかね。 質問タグとバージョン情報追加されたほうが良いです。 ちなみに、デバッグはされましたか?想定の分岐を通っているか、保持する値くらいはすぐ確認できます
yoheiiii

2023/04/18 03:46

Laravel Framework 6.20.44 PHP 7.2.34 になります。 4の方を$inputdata = 'test'; にしたのですが、1の方の処理に入っています。 試しに$test[] = $val[$key][0]; を入れて値をみると array:4 [ 0 => "1" 1 => "y" 2 => "k" 3 => "1" ] という結果が返ってきました。
yoheiiii

2023/04/18 04:57

DBの構造が間違っておりました。 色々ご教授ありがとうございました。
m.ts10806

2023/04/18 06:52

だとしたらベストアンサーに選んだ回答は違うのでは? 質問者自身も回答投稿できるので、具体的にどこがどう間違っていたのか、解決までの顛末を記載されたほうが良いと思います。
guest

回答2

0

DBを作る際
PRIMARY KEY (Seq) USING BTREE
として、USING BTREEをつけて作成してしまった。
その為同じ値が複数件登録されてしまっていた。
USING BTREEを取り除いてDBを作成したところ
問題なく登録されるようになりました。

投稿2023/04/20 07:19

yoheiiii

総合スコア87

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

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

0

ベストアンサー

問題なさそうです。提示されたソース以外の問題かもしれません。
もっとわかりやすく

PHP

1 if($val[0] === '4'){ 2 $inputdata = "test";

のようなテストをしてみてください

投稿2023/04/18 03:25

yambejp

総合スコア114784

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問