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

Фильтр по полю даты и времени, допускающему значение NULL, с помощью Linq

Я пытаюсь отфильтровать все строки в таблице SQL с определенной датой. Он работает, если столбец не допускает значения NULL, но не работает, если это так.

Это работает для полей даты и времени, не допускающих значения NULL:

ent.MyTable.Where(e => e.MyDate.Day == 12);

Очевидно, это работает не для полей даты и времени, допускающих значение NULL. После некоторого поиска в Интернете я нашел множество «решений» этой проблемы, которые выглядят следующим образом:

ent.MyTable.Where(e => e.MyDate != null && e.MyDate.Day == 12);

К сожалению, у меня это тоже не работает. И понятно, почему, если я рассматриваю это сообщение об ошибке:

'System.Nullable' не содержит определения для 'Day', и не может быть найден метод расширения 'Day', принимающий первый аргумент типа 'System.Nullable' (вам не хватает директивы using или ссылки на сборку?)

Я хочу избежать выборки всех строк SQL с последующей фильтрацией в .NET, поскольку меня интересует только очень небольшое количество строк. Есть ли другой способ, которого я не вижу в данный момент?


  • MyDate определен как допускающий значение NULL DateTime в ваших классах? Если это так, ваша вторая строка не должна компилироваться. В противном случае ваша модель не соответствует базе данных. 05.08.2016

Ответы:


1

Использовать свойство значения даты, допускающей значение NULL

ent.MyTable.Where(e => e.MyDate.HasValue && e.Date.Value.Day == 12);
05.08.2016
  • Исправьте свой ответ, должно быть ent.MyTable.Where(e => e.MyDate.HasValue && e.Date.Value.Day == 12); 05.08.2016
  • @AdilMammadov HasValue и != null эквивалентны для типов, допускающих значение NULL. 05.08.2016
  • @Mostafiz самый быстрый ответ, который я когда-либо получал! Большое Вам спасибо. Приму ответ как можно скорее :) 05.08.2016
  • @ user3185569 было написано как e.MyDate.Value != null 05.08.2016
  • почему отрицательный голос я обновил свой ответ из sugesion, я вернулся в исходное состояние сейчас 05.08.2016
  • @Mostafiz, вы торопитесь, вы вернулись к исходной версии e.MyDate.Value != null. должно быть e.MyDate.HasValue или e.MyDate != null :) 05.08.2016
  • Это должно быть e.MyDate != null 05.08.2016

  • 2

    Попробуй это:

     ent.MyTable.Where(e => e.MyDate.HasValue && e.MyDate.Value.Day == 12);
    
    05.08.2016
    Новые материалы

    Основы принципов S.O.L.I.D, Javascript, Git и NoSQL
    каковы принципы S.O.L.I.D? Принципы SOLID призваны помочь разработчикам создавать надежные, удобные в сопровождении приложения. мы видим пять ключевых принципов. Принципы SOLID были разработаны..

    Как настроить Selenium в проекте Angular
    Угловой | Селен Как настроить Selenium в проекте Angular Держите свое приложение Angular и тесты Selenium в одной рабочей области и запускайте их с помощью Mocha. В этой статье мы..

    Аргументы прогрессивного улучшения почти всегда упускают суть
    В наши дни в кругах веб-разработчиков много болтают о Progressive Enhancement — PE, но на самом деле почти все аргументы с обеих сторон упускают самую фундаментальную причину, по которой PE..

    Введение в Джанго Фреймворк
    Схема «работать умно, а не усердно» В этой и последующих статьях я познакомлю вас с тем, что такое фреймворк Django и как создать свое первое приложение с помощью простых и понятных шагов, а..

    Настольный ПК как «одно кольцо, чтобы править всеми» домашних компьютеров
    Вид после 9 месяцев использования С настольных компьютеров все началось, но в какой-то момент они стали «серверами», и мы все перешли на ноутбуки. В прошлом году я столкнулся с идеей настольных..

    Расширенные методы безопасности для VueJS: реализация аутентификации без пароля
    Руководство, которое поможет вам создавать безопасные приложения в долгосрочной перспективе Безопасность приложений часто упускается из виду в процессе разработки, потому что основная..

    стройный-i18следующий
    Представляем стройную оболочку для i18next. Эта библиотека, основанная на i18next, заключает экземпляр i18next в хранилище svelte и отслеживает события i18next, такие как languageChanged,..