Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/18: Рейтинг темы: голосов - 18, средняя оценка - 4.67
 Аватар для SKonst
37 / 25 / 15
Регистрация: 14.12.2013
Сообщений: 67

[EF] Указан недопустимый путь Include. Тип не объявляет свойство навигации

15.07.2015, 14:47. Показов 3569. Ответов 5

Студворк — интернет-сервис помощи студентам
Есть модель, сгенерированная из базы:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public class Judge
    {
        public int id { get; set; }
 
        public string Name { get; set; }
 
        public int Court_id { get; set; }
 
        public string Notes { get; set; }
 
        public virtual Court Courts { get; set; }
    }
public partial class Court
    {
        public Court()
        {
            Judge = new HashSet<Judge>();
        }
        public int id { get; set; }
 
        public string Name { get; set; }
 
        public string Notes { get; set; }
 
        public virtual ICollection<Judge> Judge { get; set; }
    }
собственно проблема в том, что в контроллере, когда мне нужно использовать "жадную загрузку"
C#
1
var jud = _db.Judge.Include(x=>x.Court_id).ToList();
вылетает эксепшен:
Указан недопустимый путь Include. Тип EntityType "Test.Models.Judge" не объявляет свойство навигации с именем "Courts_id".

Причем атрибуты типа ForeignKey не помогают, всегда одна и та же ошибка
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.07.2015, 14:47
Ответы с готовыми решениями:

Недопустимый путь. Убедитесь, что путь указан правильно и
Мне скинули БД, при открытии в ней любого объекта влезает такая ерунда...

Не могу создать папку на рабочем столе – выпадает ошибка – “не удалось создать папку – Указан недопустимый путь. Что делать ?
Не могу создать папку на рабочем столе – выпадает ошибка – “не удалось создать папку – Указан недопустимый путь. Что делать ? Я думаю что...

Указан недопустимый объект!...??
Доброго времени суток. Такой вот косяк: есть форма для обработки заявки клиента, в ней поле 'Клиент', значение которого подставляется из...

5
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18267 / 14190 / 5368
Регистрация: 17.03.2014
Сообщений: 28,879
Записей в блоге: 1
15.07.2015, 14:54
Лучший ответ Сообщение было отмечено SKonst как решение

Решение

SKonst, свойство навигации в EF это коллекция сущностей или сущность. В данном случае надо использовать поле Courts
C#
1
var jud = _db.Judge.Include(j => j.Courts).ToList();
P.S. При генерации модели неправильно использовалось единственное и множественное число для навигационных свойств. Оно не мешает работе, но вносит путаницу. Judge.Courts лучше переименовать в Judge.Court, а Court.Judge в Court.Judges
1
 Аватар для SKonst
37 / 25 / 15
Регистрация: 14.12.2013
Сообщений: 67
15.07.2015, 15:01  [ТС]
OwenGlendower, Спасибо! А не подскажите тогда как избавиться вот от такой проблемы? "При сериализации объекта типа "Test.Models.Judge" обнаружена циклическая ссылка." Сериализую в Json
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18267 / 14190 / 5368
Регистрация: 17.03.2014
Сообщений: 28,879
Записей в блоге: 1
15.07.2015, 15:20
SKonst, в каком контексте это возникает? При попытке сериализовать значения этих классов или в какой-то другой?
0
 Аватар для SKonst
37 / 25 / 15
Регистрация: 14.12.2013
Сообщений: 67
15.07.2015, 15:57  [ТС]
OwenGlendower, при сериализации свойства
C#
1
public virtual Court Courts { get; set; }
как я понял, вот полный код контроллера:
C#
1
2
3
4
5
6
7
public JsonResult Index()
        {
            Model1 _db = new Model1();
            var jud = _db.Judge.Include(p => p.Courts).ToList();
            return Json(jud, JsonRequestBehavior.AllowGet);
 
        }
В гугле предлагают в модели у свойства Courts выставить атрибут [ScriptIgnore], но тогда пропадает весь смысл метода Include
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18267 / 14190 / 5368
Регистрация: 17.03.2014
Сообщений: 28,879
Записей в блоге: 1
15.07.2015, 16:31
SKonst, циклическая свзяь здесь в самом деле есть. Оба класса ссылаются друга на друга. ScriptIgnore можно поставить у Court.Judge или создать отдельную модель (не EF!) для JSON сериализации без циклов.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.07.2015, 16:31
Помогаю со студенческими работами здесь

Ошибка: указан недопустимый обьект, или обьект более не задан
Что не так в этом коде ? Sub abv() Dim rst As Recordset, str As String, i As Byte, fld As String Dim tdf As TableDef

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

Недопустимый путь
Есть база ,лежит в папке с exe..если добавлять через запрос ,все работает. Но при подключении dataGridView пишет ошибку ,а именно что...

путь в MapPath указан неверно
Проблема передачи файла от клиента на сервер. if (upload_file.PostedFile != null) { string filename =...

Неправильно указан путь к файлы
Данная проблема возникла сегодня второй раз На жестком диске 2 папки program files windows 7 Как исправить?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru