Как использовать, если условие в поле зрения отношение модели. Laravel [дубликат]

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

См. также: A хороший список лучших практик

Я бы добавил, очень важно, хорошо использовать модификатор final. Использование "окончательной" модификатор, когда это применимо в Java

Сводка:

  1. Используйте модификатор final для обеспечения хорошей инициализации.
  2. Избегайте возврата null в методы, например, при возврате пустых коллекций.
  3. Использовать аннотации @NotNull и @Nullable
  4. Быстрое завершение работы и использование утверждений, чтобы избежать распространения нулевых объектов через все приложение, когда они не должен быть пустым.
  5. Сначала используйте значения с известным объектом: if("knownObject".equals(unknownObject)
  6. Предпочитают valueOf() поверх toString ().
  7. Используйте null safe StringUtils StringUtils.isEmpty(null).

0
задан Rickkwa 25 March 2015 в 21:42
поделиться

2 ответа

Пустые функции не нужны. Laravel достаточно умен, чтобы работать со смешанным набором отношений с ограничениями и без них.

Entry::with(array(
    'foo' => function($query) use ($id) {
        $query->where('user_id', $id);
    },
    'author',
    'lastModifiedBy'
))->...;

Как это работает

Вот как Laravel различает два:

в Illuminate\Database\Eloquent\Builder@parseRelations

foreach ($relations as $name => $constraints)
{
    // If the "relation" value is actually a numeric key, we can assume that no
    // constraints have been specified for the eager load and we'll just put
    // an empty Closure with the loader so that we can treat all the same.
    if (is_numeric($name))
    {
        $f = function() {};
        list($name, $constraints) = array($constraints, $f);
    }

Как описывает комментарий, Laravel фактически добавляет пустое замыкание сам по себе, если ключ элемента массива является числовым.

2
ответ дан lukasgeiter 18 August 2018 в 13:21
поделиться

Вы не выполняете эти пустые функции. Вы можете напрямую поместить на них отношения.

Entry::with(array(
    'foo' => function($query) use ($id) {
        $query->where('user_id', $id);
    },
    'author', 'lastModifiedBy'
))->...;

Или, альтернативно, вы можете поместить те, которые вложены в метод.

Entry::with(array(
    'foo' => function($query) use ($id) {
        $query->where('user_id', $id);
    }
))
->with('author', 'lastModifiedBy')->...;
0
ответ дан Sushant Aryal 18 August 2018 в 13:21
поделиться
Другие вопросы по тегам:

Похожие вопросы: