質問編集履歴

1 文言の修正

T.FUJII

T.FUJII score 19

2018/05/31 17:38  投稿

Laravelで配列の中身の差を確認したい
###前提・実現したいこと
新人のエンジニアです。至らぬ点もあると思いますが、お手柔らかにおねがいします。
DBのデータと、これから登録しようとしている(CSVファイルの)データを比較し、
もし差があれば、DB UPDATE処理をする。
その際に編集されたというカラム(編集チェック)の値を0から1に書き換えたい。
**全体の流れ**
```
// データベースからデータを取得
$dbCompaniesTableData = Company::where("id", $id)->first();
// コレクションを配列に変換
$dbCompaniesTableData = $dbCompaniesTableData->toArray();
// dump & die
dd($dbCompaniesTableData);
```
上記のコードでデータベースから取得したレコードの形式。
array:8 [▼
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 => "001"
 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
  • PHP

    29175 questions

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

  • Laravel 5

    3068 questions

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

思考するエンジニアのためのQ&Aサイト「teratail」について詳しく知る