Форум программистов, компьютерный форум, киберфорум
LINQ
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
Рожденная для битвы
 Аватар для marina2
294 / 72 / 15
Регистрация: 08.11.2009
Сообщений: 1,272

Связь один ко многим

27.06.2018, 07:14. Показов 1369. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В базе две таблицы связаны 1:мн. Пытаюсь добавить данные во вторую таблицу, возникает исключение.

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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
 private void button1_Click(object sender, EventArgs e)
        {
 
            Name1 = textBox1.Text;
            Tel1= textBox2.Text;
            Adress1=textBox3.Text;
            Citty=Town.Text;
            Ustr=textBox5.Text;
            Person user1 = new Person
            {
                Id = 1,
                Name = Name1,
                Tel = Tel1
 
            };
 
 
             using (ManEntities db = new ManEntities())
            {
                db.Person.Add(user1);
                db.SaveChanges();
                var query = from fw in db.Person
                             where fw.Name == Name1
                            select fw;
                foreach (Person p in query)
                    i = p.Id;
                              
            }
                       
 
            Device dev = new Device
            {
                Id = 1,
                IdForPerson = i,
                Adress =Adress1,
                City=Citty,
                Model=Ustr
            };
 
            using (ManEntities db = new ManEntities())
            {
                db.Device.Add(dev);
                db.SaveChanges();
            }
 
        }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.06.2018, 07:14
Ответы с готовыми решениями:

Реализовать связь "многие ко многим"
Добрый день, уважаемый форумчане! Описываю сущности: Books: ISBN, Title, Genre_id, Publish_date, Upload_date, Annotation, Book_rating ...

Entity Framework 6. Code First. Связь один-ко-многим и многие-ко-многим одновременно
Здрасти. Есть таблица юзеров и объявлений. У юзера может быть множество объявлений. Здесь действует связь один-ко-многим. Но юзер также...

Устанавливается связь один-к-одному вместо один-ко-многим
Здравствуйте, скажите пожалуйста почему между данными таблицами устанавливается связь один-к-одному вместо один-ко-многим, в таблице...

5
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
27.06.2018, 10:35
Цитата Сообщение от marina2 Посмотреть сообщение
возникает исключение.
Какое? Что говорит?

Цитата Сообщение от marina2 Посмотреть сообщение
C#
1
2
3
4
5
6
7
            Person user1 = new Person
            {
                Id = 1,
                Name = Name1,
                Tel = Tel1
 
            };
Этот код отработает только в том случае, когда в базе еще нет записи с Id, равной 1.
Все последующие разы будет исключение.

Цитата Сообщение от marina2 Посмотреть сообщение
C#
1
2
3
var query = from fw in db.Person
   where fw.Name == Name1
   select fw;
Почему производится поиск по имени, а не по Id?

Цитата Сообщение от marina2 Посмотреть сообщение
C#
1
2
foreach (Person p in query)
   i = p.Id;
А зачем одной и той же переменной присваивать новое значение в цикле?
Колонка Name в таблице — уникальна?

Цитата Сообщение от marina2 Посмотреть сообщение
C#
1
2
3
4
5
6
7
8
            Device dev = new Device
            {
                Id = 1,
                IdForPerson = i,
                Adress =Adress1,
                City=Citty,
                Model=Ustr
            };
Здесь то же самое, что и в первом случае: код отработает корректно только на пустой таблице.
0
Рожденная для битвы
 Аватар для marina2
294 / 72 / 15
Регистрация: 08.11.2009
Сообщений: 1,272
27.06.2018, 12:11  [ТС]
'System.Data.Entity.Infrastructure.DbUpd ateException' occurred in EntityFramework.dll


Добавлено через 1 минуту
Цитата Сообщение от kolorotur Посмотреть сообщение
Этот код отработает только в том случае, когда в базе еще нет записи с Id, равной 1.
Единица стоит потому, что id генерируется автоматически в базе. Поэтому идет поиск по имени.
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
27.06.2018, 12:23
Цитата Сообщение от marina2 Посмотреть сообщение
'System.Data.Entity.Infrastructure.DbUpd ateException' occurred in EntityFramework.dll
Там еще есть InnerExcetpion — смотрите всю иерархию.

Цитата Сообщение от marina2 Посмотреть сообщение
Единица стоит потому, что id генерируется автоматически в базе.
Тогда не ставьте вообще ничего, пусть будет значение по умолчанию (0).

Цитата Сообщение от marina2 Посмотреть сообщение
Поэтому идет поиск по имени.
При вызове SaveChanges экземпляр обновляется, получая сгенерированное Id.
1
Рожденная для битвы
 Аватар для marina2
294 / 72 / 15
Регистрация: 08.11.2009
Сообщений: 1,272
27.06.2018, 12:40  [ТС]
DbUpdateException was unhanhandled

An unhandled exception of type 'System.Data.Entity.Infrastructure.DbUpd ateException' occurred in EntityFramework.dll
Additional information: An error occurred while updating the entries. See the inner exception for details.
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
27.06.2018, 12:43
marina2,
Цитата Сообщение от marina2 Посмотреть сообщение
See the inner exception for details.
Говорю же:
Цитата Сообщение от kolorotur Посмотреть сообщение
смотрите всю иерархию.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.06.2018, 12:43
Помогаю со студенческими работами здесь

Связь один - к многим
Добрый день. Есть две таблицы, связанные между собой 1:М. Я делал выборки с помощью JOIN но строка из первой таблицы повторяется столько...

Связь один ко многим
Привет! Вопрос нубский, но я завис... пытаюсь связать одну таблицу с другой.

Связь один ко многим
Как сделать данную связь? Чтобы при выборе значения в комбобоксе, показывалось 3 значения. А именно при выборе отдела, должно выводится в...

Связь один ко многим
Как сделать, чтобы была возможность вводить повторяющиеся данные? (есть связь с другой таблицей, в которой данные данные о людях, а в этой...

Связь один ко многим
Добрый вечер. Есть такая база данных: Надо сделать так, чтобы в при заполнении таблицы заказ мы могли выбрать любое количество...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru