Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
2 / 2 / 0
Регистрация: 14.10.2011
Сообщений: 89

Не сохраняет в базу изменения

08.05.2014, 01:36. Показов 1268. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть форма с dgv. При нажатие на кнопку "изменить данные" открывается новая форма, где выводится в текстбоксы данные текущей строки dgv. Дальше при удачном заполнении, создаю DataRow и изменяю данные. В dgv выводи изменения, но в саму базу не заносятся(т.е. после перезапуска приложения, данные прежние). В DataRow похоже не сохраняется строка. Как исправить данную проблему?
Форма с dgv
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
  private void button4_Click(object sender, EventArgs e)
        {
 
            string kod = dgv_med[0, dgv_med.CurrentRow.Index].Value.ToString();
            string name = dgv_med[1, dgv_med.CurrentRow.Index].Value.ToString();
            string typemed = dgv_med[2, dgv_med.CurrentRow.Index].Value.ToString();
            EditMed EditMed = new EditMed(kod, name, typemed);
 
            if (EditMed.ShowDialog() != DialogResult.OK)
            {
                MessageBox.Show("Мед. учреждение не изменено");
                return;
            }
          
            DataRow myRow = DataSet.Tables["MedTable"].Rows.Find(kod);
                  myRow.BeginEdit();
                myRow["Kod_med"] = EditMed.MedId;
                myRow["Nazvanie"] = EditMed.MedName;
                myRow["Type"] = EditMed.MedType;
                myRow.EndEdit();
                DataSet.Tables["MedTable"].AcceptChanges();
                dal.SaveChanges(DataSet);
            }
Новая форма
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
 public partial class EditMed : Form
    {
 
        public int MedId
        {
            get { return int.Parse(txtKod.Text); }
        }
 
        public string MedName
        {
            get { return txtName.Text.Trim(); }
        }
 
        public string MedType
        {
            get { return txtType.Text.Trim(); }
        }
        public EditMed(string Kod, string name, string typemed)
        {
            InitializeComponent();
            txtKod.Text = Kod;
           txtName.Text = name;
           txtType.Text = typemed;
           txtKod.Text.Trim();
            txtName.Text.Trim();
           txtType.Text.Trim();
        }
 
        private void btn_saveEditMed_Click(object sender, EventArgs e)
        {
 
            if (String.IsNullOrEmpty(txtKod.Text.Trim()) ||
                String.IsNullOrEmpty(txtName.Text.Trim()) ||
                String.IsNullOrEmpty(txtType.Text.Trim())
                )
                DialogResult = DialogResult.No;
            else
                DialogResult = DialogResult.OK;
        }
    }
Обновление данных
C#
1
2
3
4
5
6
7
8
9
10
11
12
 internal bool SaveChanges(DataSet DataSet_)
        {
            try
            {
                medDA.Update(DataSet_.Tables["MedTable"]);
            }
            catch
            {
                return false;
            }
            return true;
        }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.05.2014, 01:36
Ответы с готовыми решениями:

ADODataSet не сохраняет изменения
Доброго времени суток, возникла проблема. после модификации ячеек таблицы подключенной через adoDataSet не сохраняются данные после...

UPDATE не сохраняет изменения в БД
Всем привет! Я только начинаю изучать программирование и столкнулся с проблемой которую не могу решить более трех дней. Все вроде...

не сохраняет изменения Тип данных
При изменении: Тип данных на Денежный, Формат поля: Денежный. Формат поля изменяется на Евро при новом открытии таблицы.

6
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
08.05.2014, 07:17
Где подключение, создание адаптеров и прочее? Ты адаптеру назначил команды для сохранения данных?
0
2 / 2 / 0
Регистрация: 14.10.2011
Сообщений: 89
08.05.2014, 09:57  [ТС]
Да, подключал. Добавление и удаление данные данных отлично работают.

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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
 class Dal
    {
        
        string connectionString = ConfigurationManager.ConnectionStrings["RSPK1managerConnectionString"].ConnectionString;
        DataSet DataSet;
        SqlDataAdapter medDA, prihodDA;
        SqlCommandBuilder MedCB;
        public Dal()
        {
            DataSet = new DataSet("RSPK");
            medDA = new SqlDataAdapter("SELECT * FROM Med ORDER by Kod_Med", connectionString);
            prihodDA = new SqlDataAdapter("SELECT * FROM prihod ORDER by Kod_prihod", connectionString);
            
            //Билдер вставка удаление обновление данных
            MedCB = new SqlCommandBuilder(medDA);
            //Добавление мед. учреждения
          /*  medDA.InsertCommand = new SqlCommand();
            medDA.InsertCommand.Connection = new SqlConnection(connectionString);
            medDA.InsertCommand.CommandType = CommandType.Text;
            medDA.InsertCommand.CommandText = string.Format(
                "INSERT INTO Med (Kod_med, Nazvanie, Type) Values (@Kod_med, @Nazvanie, @Type);");
            medDA.InsertCommand.Parameters.Add(new SqlParameter("@Kod_med", SqlDbType.Int, 0, "Kod_med"));
            medDA.InsertCommand.Parameters.Add(new SqlParameter("@Nazvanie", SqlDbType.VarChar, 0, "Nazvanie"));
            medDA.InsertCommand.Parameters.Add(new SqlParameter("@Type", SqlDbType.NVarChar, 0, "Type"));*/
                
            
        }
 
        public DataSet GetAllData()
        {
            try
            {
                medDA.Fill(DataSet,"MedTable");
                prihodDA.Fill(DataSet, "PrihodTable");
                DataSet.Tables[0].PrimaryKey = new DataColumn[] { DataSet.Tables[0].Columns[0] };
                DataSet.Tables[0].Columns[0].Unique = true;
 
                DataRelation prskDR = new DataRelation("Medprihod",
                 DataSet.Tables["MedTable"].Columns["Kod_med"],
                 DataSet.Tables["PrihodTable"].Columns["Kod_otprav"]);
 
                DataSet.Relations.Add(prskDR);
            }
            catch
            {
 
            }
 
            return DataSet;
        }
 
        internal bool SaveChanges(DataSet DataSet_)
        {
            try
            {
                medDA.Update(DataSet_.Tables["MedTable"]);
            }
            catch
            {
                return false;
            }
            return true;
        }
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
08.05.2014, 13:17
Вот это вообще работает?
C#
1
dal.SaveChanges(DataSet);
Придумай имя не совпадающее с типом, например ds.

Добавлено через 2 минуты
И в классе и в самой функции тоже.
0
2 / 2 / 0
Регистрация: 14.10.2011
Сообщений: 89
08.05.2014, 13:43  [ТС]
Использую эту же функцию SaveChanges для добавление и удаления, там работает. По идеи должна работать.

Что-то я не понял, создать новый столбец в datarow и в классе editform? Можно поподробнее.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
08.05.2014, 14:09
Я говорю, что DataSet - имя класса, поэтому не надо давать такие имена переменным.

Добавлено через 1 минуту
Посмотри в отладчике, что происходит после rows.find. Вносятся изменения или нет в строку.
0
2 / 2 / 0
Регистрация: 14.10.2011
Сообщений: 89
08.05.2014, 14:21  [ТС]
Проблему устранил. Оказалось, что DataSet.Tables["MedTable"].AcceptChanges(); не нужен.

"DataSet.AcceptChanges помечает датасет как неизменённый.

Чтобы сохранить данные, нужно вызвать у адаптера Update. При этом на все несохранённые изменения сгенерятся команы обновления БД. Соответственно, если AcceptChanges вызвать перед этим, в БД тоже ничего не сохранится."
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.05.2014, 14:21
Помогаю со студенческими работами здесь

Файл css не сохраняет изменения
В чем может быть проблема, вношу изменения в файл css, сохраняю, обновляюсь на сайте, изменений нет? Открываю css файл, параметры остались...

Не сохраняет изменения в БД через TableAdapter
Добрый день! Возникла следующая проблема. Есть таблица в БД в ней нужно изменить значение одной из ячеек. Использую следующий метод ...

Не сохраняет изменения в формате csv
Добрый день! я столкнулась с проблемой: не сохраняются изменения, сделанные в csv формате. я пыталась переконвертировать формат экселя в...

Builder не сохраняет изменения в проекте
Чтобы изменения кода программы вступили в силу, приходится постоянно закрывать Builder , удалять все файлы сохраненные самим Builder-ом , и...

Сохраняет изменения в таблице по настроению
Я в Делфи нулевой, пока ещё учусь и многого не знаю. Так что сильно не ругайтесь за тупой вопрос, но поиск по форуму мне не дал рабочего...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru