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

Linq to entity: хранимая процедура + установка свойств навигации

Я устанавливаю сущность объекта с помощью хранимой процедуры, но свойства навигации всегда равны нулю...

Цель состоит в том, чтобы включить или присоединиться к внешней сущности.

Есть идеи ?

Спасибо

23.02.2010

Ответы:


1

Вы должны «загрузить» свои навигационные свойства перед доступом к ним. Если навигация представляет собой коллекцию, используйте

yourNavigationPropertyName.Load();

если это один объект, используйте связанное свойство ссылки:

yourNavigationPropertyNameReference.Load();

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

ADO.NET Entity Framework загружается и загружается

23.02.2010
  • Это один объект, я буду использовать связанное свойство ссылки, спасибо. Моя проблема заключается в том, что все внешние ключи (свойства навигации) имеют значение null, когда я устанавливаю сущность объекта с помощью хранимой процедуры, поэтому я не могу выполнить загрузку. Я не знаю почему... Мой код: var sp = context.GetUserEntityTransactions(SesameId); Список‹Транзакция›transactions = новый Список‹Транзакция›(sp.ToList()); Внешние ключи транзакций равны нулю 23.02.2010
  • Как насчет того, чтобы попробовать sp.Load(); Список транзакций = новый список (sp.ToList()); ? 23.02.2010

  • 2

    Это один объект, я буду использовать связанное свойство ссылки, спасибо. Моя проблема заключается в том, что все внешние ключи (свойства навигации) имеют значение null, когда я устанавливаю сущность объекта с помощью хранимой процедуры, поэтому я не могу выполнить «загрузку». Я не знаю, почему...

    Мой код:

    var sp = context.GetUserEntityTransactions(SesameId); 
    

    Список транзакций = новый список (sp.ToList());

    Внешние ключи транзакций равны нулю

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

    Основы принципов 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,..