Nano Hash - криптовалюты, майнинг, программирование

Получить все записи, где возраст меньше, чем разница в дате в laravel

Я пытаюсь получить все записи детей, возраст которых меньше 5 лет.

Дата для расчета возраста должна быть датой в будущем, например, 2021-08-12.

$date и $age являются пользовательскими.

$date может быть любой будущей датой, а $age — числом (например, 5)

Я написал следующее, но это не работает.

$children=Child::whereRaw('DATEDIFF('.$date.', date_of_birth) < '.$age.'')
                ->get();

Здесь date_of_birth — столбец в БД.


Ответы:


1

Чтобы избежать необработанных выражений и сложных запросов, вы можете использовать виртуальные столбцы.

1. Добавьте это в столбец "Миграция после created_at" или вы можете создать новую миграцию.

$table->char('date_of_birth_year',3)->virtualAs('DATE_FORMAT(FROM_DAYS(DATEDIFF(CURRENT_DATE, date_of_birth)),"%y")');

Запустите миграцию

Теперь вы можете выполнить следующий запрос, чтобы получить записи, созданные в определенный месяц.

$yearsOld = ['01', '02', '03', '04'];

$childrens = Child::query()
    ->whereIn('date_of_birth_year', $yearsOld)
    ->get();

Если вы хотите узнать больше, проверьте ссылки ниже

  1. https://laravel.com/docs/8.x/migrations#column-modifiers
  2. https://www.w3schools.com/sql/func_mysql_date_format.asp
09.02.2021

2

Вы можете использовать метод whereBetween. И сравните его с now() или любым другим датой и временем

Child::whereBetween('date_of_birth', [now()->subYears(5), now()])->get();
08.02.2021
  • date_of_birth - это дата, хранящаяся в БД, я хочу различать только пользовательскую дату $. Этот запрос дает мне записи между двумя датами. Не решение! 08.02.2021
  • @KaleemShoukat. Я обновил его, чтобы дать явное решение. Вы должны date_of_birth между настоящим моментом и настоящим минус 5 лет. 08.02.2021
  • Спасибо за помощь, но это не решение. 08.02.2021

  • 3

    Наконец, после отладки я нашел решение. Проблема заключалась в том, что $date не передавалось как строка, из-за чего дни не были найдены, и мне пришлось конвертировать дни в годы. Это может помочь кому-то.

    $children=Child::whereRaw('(DATEDIFF("'.$date.'",date_of_birth)/365) < '.$age.'')
              ->get();
    
    08.02.2021
    Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..