Member 14615938 Ответов: 1

Этот метод или свойство не могут быть вызваны для нулевых значений в ASP.NET ядро 3


In the table of cars, add a number of fields that are not required and can not be entered in the table.
But I have encountered the following error

this method or property cannot be called on null values


Что я уже пробовал:

<pre>            var cars = await DbContext.Cars.ToListAsync();
            cars.Insert(0, new Cars { CarTitle = "", Id = -1 });
            ViewData["CarId"] = new SelectList(cars, "Id", "CarTitle");

Sandeep Mewara

Что такое схема БД? Является ли заголовок обязательными данными для передачи? Общий доступ к модели Cars, отображенной в entity framework, которая сохраняется в БД.

Поверьте, что где-то есть значение DBNULL, которое не ожидается/не обрабатывается.

1 Ответов

Рейтинг:
0

OriginalGriff

Это одна из самых распространенных проблем, которые нам задают, и это также та, на которую мы меньше всего готовы ответить, но вы больше всего готовы ответить сами.

Позвольте мне просто объяснить, что означает ошибка: вы пытались использовать переменную, свойство или возвращаемое значение метода, но оно содержит null - что означает, что в переменной нет экземпляра класса.
Это немного похоже на карман: у вас есть карман в рубашке, который вы используете, чтобы держать ручку. Если вы сунете руку в карман и обнаружите, что там нет ручки, вы не сможете подписать свое имя на листе бумаги - и вы получите очень смешные взгляды, если попытаетесь! Пустой карман дает вам нулевое значение (здесь нет ручки!), поэтому вы не можете сделать ничего, что обычно делали бы, когда вы извлекли свою ручку. Почему он пуст? Вот в чем вопрос - может быть, вы забыли взять ручку, когда уходили из дома сегодня утром, или, возможно, вы оставили ручку в кармане вчерашней рубашки, когда снимали ее вчера вечером.

Мы не можем сказать, потому что нас там не было, и, что еще важнее, мы даже не можем видеть вашу рубашку, не говоря уже о том, что находится в кармане!

Вернемся к компьютерам, и вы каким - то образом сделали то же самое-и мы не можем увидеть ваш код, а тем более запустить его и узнать, что содержит null, когда это не должно быть.
Но вы можете - и Visual Studio поможет вам здесь. Запустите свою программу в отладчике, и когда она выйдет из строя, VS покажет вам строку, в которой она обнаружила проблему. Затем вы можете начать просматривать различные его части, чтобы увидеть, какое значение равно null, и начать просматривать свой код, чтобы узнать, почему. Поэтому поставьте точку останова в начале метода, содержащего строку ошибки, и снова запустите программу с самого начала. На этот раз VS остановится перед ошибкой и позволит вам изучить, что происходит, пройдя через код, глядя на ваши значения.

Но мы не можем этого сделать - у нас нет вашего кода, мы не знаем, как его использовать, если бы он у нас был, у нас нет ваших данных. Так что попробуйте - и посмотрите, сколько информации вы можете узнать!


Member 14615938

Я написал этот метод следующим образом:
частной задачей асинхронных&ЛТ;интерфейс IEnumerable&ЛТ;saletotalsaleviewmodel&ГТ;&ГТ; GetSaleTotalSalesAsync(
инт? carId = null, строка fromDate = null, строка устареет = нуль)
.......
Теперь, когда я хочу определить автомобили в методе FirstOrDefaultAsync, я не могу использовать метод ToListAsync

ВАР = ждут DbContext можно.Автомобили
.FirstOrDefaultAsync(m => m.Id == карид)
.ToListAsync();

Выдает ошибку по методу ToListAsync

OriginalGriff

И что же?
Что вам показал отладчик?

При предположении - и это очень хорошее предположение - совпадающих элементов нет, поэтому FirstOrDefault возвращает null. Вызовите метод (любой метод) на null, и вы правильно получите ошибку. Поэтому вам нужно сделать две вещи:
1) выясните, почему у вас нет подходящих предметов.
2) изящно справляйтесь с ситуацией "нет совпадения" вместо того, чтобы предполагать, что она всегда будет работать.

Member 14615938

Прежде чем я добавлю новые поля
Он правильно работал с этим кодом : var cars = await DbContext.Cars.ToListAsync();
Затем, в соответствии с необходимостью, я добавил три новых поля и дал ему разрешение быть нулевым в базе данных.
Почему эта ошибка возникает, несмотря на значение allow null?
Теперь, когда я пишу следующий код
ВАР = ждут DbContext можно.Автомобили
.FirstOrDefaultAsync(m => m.Id == карид)
.ToListAsync();

Я пойду с этой ошибкой в .ToListAsync();

Описание Серьезности Состояние Подавления Источника Строки Столбца Файла Проекта
Ошибка тип "OfficesController" уже содержит определение для тестовых файлов "UpdateExists" E:\Project\TestVS\Controllers\OfficesController.cs 158 22 IntelliSense активен