Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
177 / 158 / 12
Регистрация: 03.11.2012
Сообщений: 1,113

Сохранение в БД из DataGridView

27.07.2018, 19:32. Показов 622. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть БД 3 столбца и несколько строк.
Загружаю их в datagridview так:
C#
1
2
3
4
5
6
7
8
using (var context = new Database1Entities()) // контекст предоставляющий доступ к БД
            {
                foreach (var mytext in context.Table1)   // проходимся по всем строкам
                {
                    dataGridView1.Rows.Add(mytext.Column1, mytext.Column2, mytext.Column3);  // вносим данные в таблицу
                }
 
            }
Это работает.
Теперь я решил изменить данные в datagridview и сохранить и в БД.
Вот попробовал так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
int a = dataGridView1.RowCount;
int i = 0;
var strall = new Table1
            {
                Column1 = dataGridView1.Rows[i].Cells[0].Value.ToString(),
                Column2 = dataGridView1.Rows[i].Cells[1].Value.ToString(),
                Column3 = dataGridView1.Rows[i].Cells[2].Value.ToString(),
            };
            using (var context = new Database1Entities()) // контекст предоставляющий доступ к БД
            {            
                    for (i = 0; i < a; i++)
                    {
                        context.Table1.Add(strall);
                    }
 context.SaveChanges();
}
Но при сохранении пишет: "SqlException: Нарушено "PK_Table1" ограничения PRIMARY KEY. Не удается вставить повторяющийся ключ в объект "dbo.Table1". Повторяющееся значение ключа: (0 )."
В чём может быть проблема ?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.07.2018, 19:32
Ответы с готовыми решениями:

Сохранение DataGridView
Помогите, как сохранить данные в дата грид, если дата грид не связана с бд, а создана автоматически в сишарпе, данные добавляются в нее, а...

Сохранение DataGridView в БД
Ребят как реализовать такую проблему: Я загружаю таблицу из файла Excel при помощи кода: private void button4_Click(object sender,...

Сохранение datagridview
Добрый вечер) возникла проблема при сохранении datagridview(в таблице 3 столбца(, но при сохранении сохраняется только первый столбец, а...

1
 Аватар для aleksskay4
71 / 68 / 46
Регистрация: 02.12.2015
Сообщений: 891
Записей в блоге: 1
27.07.2018, 22:41
Наверно лучше так загрузить:
C#
1
  dataGridView1.DataSource = context.Table1.Local.ToBindingList();
Добавлено через 3 минуты
Цитата Сообщение от Matwei Посмотреть сообщение
using (var context = new Database1Entities()) // контекст предоставляющий доступ к БД
* * * * * * { * * * * * *
* * * * * * * * * * for (i = 0; i < a; i++)
* * * * * * * * * * {
* * * * * * * * * * * * context.Table1.Add(strall);
* * * * * * * * * * }
Тут возможно только один раз нужно добавить. И вообще лучше создать отдельную форму для редактирования и добавления.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.07.2018, 22:41
Помогаю со студенческими работами здесь

сохранение DataGridView
Здравствуйте. Помогите пожалуйста решить Такой момент: допустим есть у нас таблица с ней итерационно выполняются преобразования ...

Сохранение в Datagridview
Добрый вечер! Подскажите пожалуйста.. знаю что сохранять это командой Tableadapter.Update(dataset). это команда стоит на кнопке и все...

Сохранение DataGridView
Здравствуйте, уважаемые форумчане. Имею приложение на Windows Forms, в которой имеется DataGridView. В нем, находится текст, который я...

Сохранение изменений в БД из DataGridView
Как сохранить изменения в бд через DataGridView? Открываю бд без использования dataset. Понимаю, что нужно использовать адаптер, НО...

Сохранение данных с datagridview в БД
У меня проблема. Есть бд с 1 таблицей information, и на форме стоит datagrid view. НА форме происходят изменения таблицы в...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru