###前提・実現したいこと
新人のエンジニアです。至らぬ点もあると思いますが、お手柔らかにおねがいします。
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

回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。