Хобрук: Ваш путь к мастерству в программировании

PHP-Laravel получает данные из сводной таблицы во многих отношениях

У меня возникла проблема с извлечением конкретных данных из сводной таблицы (отношение manytomany). Сценарий состоит в том, что я хочу получить данные из сводной таблицы между двумя конкретными датами. Когда я использую этот код

$user_availability = $user->dates->where('date','>=' , $start_date)->where('date','<=' , $end_date)->get();

        foreach ($user_availability as $date)
        {
            echo $date->pivot->afternoon;
        }

Это дает мне следующую ошибку

Ошибка типа: слишком мало аргументов для функции Illuminate \ Support \ Collection :: get (), 0 передано в C: \ xampp \ htdocs \ codehacking \ app \ Http \ Controllers \ UsersController.php в строке 210 и ожидается как минимум 1

Модель пользователя:

public function dates()
{
    return $this->belongsToMany('App\Date')->withPivot('morning', 'afternoon','night','comment');
}

Сводная таблица

введите здесь описание изображения

Если вам нужно, я могу предоставить дополнительную информацию. Любая помощь будет принята с благодарностью.
Спасибо!


  • попробуйте обновить до $user_availability = $user->dates()->where('date','>=' , $start_date)->where('date','<=' , $end_date)->get(); 05.04.2018
  • @ab_ab на удивление работает! 05.04.2018
  • () преподносит сюрпризы .. 05.04.2018
  • Большое спасибо! Вы можете опубликовать ответ 05.04.2018
  • Я получал один результат без (), используя метод first(). 05.04.2018

Ответы:


1

Из документации Laravel.

Запрос отношений

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

Методы взаимоотношений Vs. Динамические свойства

Если вам не нужно добавлять дополнительные ограничения в запрос отношения Eloquent, вы можете получить доступ к взаимосвязи, как если бы это было свойство.

Измените запрос на

$user_availability = $user->dates()->where('date','>=' , $start_date)->where('date','<=' , $end_date)->get();

parenthesis используются в отношении dates для запроса отношения.

05.04.2018
Новые материалы

Не зря же это называют интеллектом
Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

LeetCode Проблема 41. Первый пропущенный положительный результат
LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

Расистский и сексистский робот, обученный в Интернете
Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

Управление состоянием в микрофронтендах
Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..

Декларативное и функциональное программирование в стиле LINQ с использованием JavaScript с использованием каррирования и генератора ...
LINQ - одна из лучших функций C #, которая обеспечивает элегантный способ написания кода декларативного и функционального стиля, который легко читать и понимать. Благодаря таким функциям ES6,..

Структуры данных в C ++ - Часть 1
Реализация общих структур данных в C ++ C ++ - это расширение языка программирования C, которое поддерживает создание классов, поэтому оно известно как C с классами . Он используется для..

Как я опубликовал свое первое приложение в App Store в 13 лет
Как все началось Все началось три года назад летом после моего четвертого класса в начальной школе. Для меня, четвертого класса, лето кажется бесконечным, пока оно не закончится, и мой отец..