Модель
"Преобразование массива в строку (SQL: обновление spent_times
набор updated_at
= 2018-10-18 07:20:22,spent_time
= 12, percentage
= 60,00, task_category
= тестирование, где id
= 7) ◀ "
<?php
public static function findOrCreate($plan_id, $data)
{
$fromDate = Carbon::now()->subDay()->startOfWeek()->toDateString();
$nowDate = Carbon::now()->today()->toDateString();
$spent_time = static::where('plan_id', $plan_id)->first();
if (is_null($spent_time)) {
return static::create($data);
} else {
$new_spent_time = SpentTime::find($plan_id);
$task_category = $new_spent_time->task_category;
$new_spent_time->task_category = (['{task_category}' => $task_category,
'{daily_spent_time}' => $new_spent_time->daily_spent_time,
'{daily_percentage}' => $new_spent_time->daily_percentage,
'{spent_time}' => $new_spent_time->spent_time,
'{percentage}' => $new_spent_time->percentage]);
$new_spent_time->spent_time = $new_spent_time::where('task_category', 'LIKE', (array)"%$task_category%")
->sum('daily_spent_time', 'LIKE', (array)"%$new_spent_time->daily_spent_time%", $fromDate);
$request['spent_time'] = (int)$new_spent_time->spent_time + $spent_time->daily_spent_time;
$new_spent_time->percentage = $new_spent_time::where('task_category', 'LIKE', (array)"%$spent_time->task_category%")
->sum('daily_percentage', 'LIKE', (array)"%$new_spent_time->daily_percentage%", $fromDate);
$request['percentage'] = (int)$new_spent_time->percentage + $spent_time->daily_percentage;
$new_spent_time->save();
return $spent_time->update($data);
}
}