Как создать список уникальных лет между несколькими датами в Lumen/LaravelPhp

Кемеровские программисты php общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Как создать список уникальных лет между несколькими датами в Lumen/Laravel

Сообщение Anonymous »

Я создаю API в Lumen, и мне нужно создать метод, который будет получать даты из двух столбцов в одной таблице и возвращаем любые годы, которые происходят между этими датами, возвращая их все как один массив.

Так, например, представьте себе столбец таблицы с именем start_date. и еще один с именем end_date

Код: Выделить всё

start_date | end_date          getAllYears() should return =>
[1983, 1984, 1985, 1986, 1987,
1999, 2000, 2001, 2002, 2003,
..., 2016]
1999-05-09 | 2002-04-03
1983-03-12 | 1987-09-23
2001-02-12 | 2016-11-27
В настоящее время у меня есть метод, который позволяет делать это с другими типами более конкретных запросов. Основная проблема этой попытки заключается в том, что из-за огромной массы записей SQL что я получаю, такой метод каждый раз приводит к таймауту моего запроса.

МОЙ НЕЭФФЕКТИВНЫЙ МЕТОД который мало использует Lumen/Laravel< /em>

Код: Выделить всё

public function getAllYears(){
$dates = $this->model->select('data_ini', 'data_fim')->get();

$results = [];

foreach ($dates as $obj){
$carbonBegin = Carbon::createFromDate($obj->data_ini->year);
$carbonEnd   = Carbon::createFromDate($obj->data_fim->year);

if($carbonEnd->year === 9999){
$carbonEnd->year = date('Y');
}

$carbonEnd->year++;
// Simple method that runs a DatePeriod method
$dateRange = $this->helper->createDateRange($carbonBegin, $carbonEnd);

$results = array_merge($results, $dateRange);
}
sort($results);
$cleanYears = array_unique($results);

if ($cleanYears == null)
return response()->json(['error' => true, 'errorCode' => '1008', 'message' => "No years found!"]);
else
return response()->json(['error' => false, 'years' => $cleanYears]);
}
Итак, вопрос в том, как я могу сделать это менее затратным способом, чтобы мой сервер не терял время ожидания при каждом запросе? Заранее благодарю за помощь :)

ПРИМЕЧАНИЕ. Использование DB:raw запрещено, поскольку мой TL запретил мне использовать его где-либо в API< /strong>

Подробнее здесь: https://stackoverflow.com/questions/369 ... en-laravel
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Как рассчитать количество лет между 2 датами?
    Anonymous » » в форуме C#
    0 Ответы
    12 Просмотры
    Последнее сообщение Anonymous
  • Laravel Lumen Migration 9-10 Ошибка Router::middleware()
    Anonymous » » в форуме Php
    0 Ответы
    7 Просмотры
    Последнее сообщение Anonymous
  • Laravel Lumen Migration 9-10 Ошибка Router::middleware()
    Anonymous » » в форуме Php
    0 Ответы
    6 Просмотры
    Последнее сообщение Anonymous
  • Laravel Lumen Migration 9-10 Ошибка Router::middleware()
    Anonymous » » в форуме Php
    0 Ответы
    12 Просмотры
    Последнее сообщение Anonymous
  • Lumen - mongodb - jensegers/laravel -mongodb - почтальон
    Anonymous » » в форуме Php
    0 Ответы
    5 Просмотры
    Последнее сообщение Anonymous

Вернуться в «Php»