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

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

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

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

Laravel 5

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

Q&A

解決済

1回答

4344閲覧

Laravelで配列の中身の差を確認したい

T.FUJII

総合スコア21

PHP

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

Laravel 5

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

0グッド

0クリップ

投稿2018/05/31 05:52

編集2018/05/31 08:38

###前提・実現したいこと

新人のエンジニアです。至らぬ点もあると思いますが、お手柔らかにおねがいします。

DBのデータと、これから登録しようとしている(CSVファイルの)データを比較し、
もし差があれば、DB UPDATE処理をする。
その際に編集されたというカラム(編集チェック)の値を0から1に書き換えたい。

全体の流れ

// データベースからデータを取得 $dbCompaniesTableData = Company::where("id", $id)->first(); // コレクションを配列に変換 $dbCompaniesTableData = $dbCompaniesTableData->toArray(); // dump & die dd($dbCompaniesTableData);

上記のコードでデータベースから取得したレコードの形式。

array:7 [▼
"id" => "001"
"phone_number" => ""
"mail_address" => ""
"home_page_url" => ""
"edited" => "0"
"created_at" => "2018-03-30 20:43:11"
"updated_at" => "2018-05-09 11:55:17"
]

// csvファイル読み込み $file = new SplFileObject($file_path); $file->setFlags(SplFileObject::READ_CSV); foreach ($file as $key => $row) { /* アップロードされたデータとDBのレコードを比較する処理(略) */ dd($row) }

対して、SplFileObjectを使い読み込んだCSVファイルは下記のような配列になっています。

array:7 [▼
0 => "1"
1 => "080-1234-5678"
2 => "test@gmail.com"
3 => "http://test.com"
4 => "0"
5 => "2018-03-30 20:43:11"
6 => "2018-05-09 11:55:17"
]

これらを比較して、例えば電話番号が追加されていたら、
編集されたという意味合いのカラム["edited"]の値を編集済みをあらわす1という数値に変えたいです。
※更新できるカラム電話とメールとホームページアドレス全てを見る、書き換えられてたら1に!

(初期値は0)

今今下記のように一つずつのカラムをチェックして書き換えが発生していたら編集されたことを表す"1"をセットし、その後DB UPDATE処理をしています。

if($row[1] !== $dbCompaniesTableData["phone_number"] ) { $dbCompaniesTableData["edited"] = 1; } if($row[2] !== $dbCompaniesTableData["mail_address"] ) { $dbCompaniesTableData["edited"] = 1; }

diffなどの関数があるみたいですが、例えば電話番号を例にすると、
コレクションから配列に変更した方だと"phone_number"、SPLで読み込んだCSVは"1"
となっており配列後と比較はできないのではないかと考えています。

もしよい方法などがあればご教授いただければと思います!
よろしくお願いします。

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

開発環境:Vagrant + VirtualBox / Homestead
本番環境:CentOS7 nginx MySQL PHP7.2
言語:PHP 7.2.3 (cli)(NTS)
フレームワーク:Laravel5.5 (LTS)
サーバー:nginx
DB:MySQL

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

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

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

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

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

guest

回答1

0

自己解決

dd(array_values($dbCompaniesTableData),$row);

array:7 [▼
0 => "001"
1 => ""
2 => ""
3 => ""
4 => "0"
5 => "2018-03-30 20:43:11"
6 => "2018-05-09 11:55:17"
]

array:7 [▼
0 => "1"
1 => "080-1234-5678"
2 => "test@gmail.com"
3 => "http://test.com"
4 => "0"
5 => "2018-03-30 20:43:11"
6 => "2018-05-09 11:55:17"
]

上記のようにarray_valuesを使うことでかなりやりたいことに近づきました。
せっかくORMを使って取得したコレクションをarrayに変換してるのは何か違う感じもしますが、
あとはdiffを使えば差がわかるというところまで来ました。もう少し考えてみます。

投稿2018/05/31 08:39

T.FUJII

総合スコア21

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問