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

TableAdapter.Update() дублирует строки в БД

13.06.2012, 01:04. Показов 1787. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте

Никак не могу понять по какой причине Adapter упорно делает дубли строк в БД с помощью метода Update().

Пример из кода:
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
switch(module)
{
                case 1:
                    {
                        #region ВЭД
                        for (var.IndexRecord = indexRowToStart + 1; var.IndexRecord < var.InternalTable.Rows.Count; var.IndexRecord++)
                        {
                            #region проверка значения
                            try
                            {
                                strSubject = var.InternalTable.Rows[var.IndexRecord][0].ToString();
 
                            }
                            catch (System.Exception err)
                            {
                            }
                            var.IdSubjNow = impData.defineParamSubjId(strSubject, cr.Data.Base.Ds.Subjects.subject_nameColumn.ToString());
 
                            #endregion проверка значения
                            for (int j = 0; j < var.Taxes_eea.Count; j++)
                            {
                                if (var.InternalTable.Rows[var.IndexRecord][j] != System.DBNull.Value &&
                                    var.IdSubjNow > 0)
                                {
                                    status = checkImportedData(var.IdSubjNow, var.YearNow, impData.returnNullFloat(var.InternalTable.Rows[var.IndexRecord][var.Taxes_eea[j][0]], 2), var.Taxes_eea[j][1], 1);
                                    if (status == 0)
                                    //Проверяем наличие в базе
                                    {
                                        add = true;
                                        var.Status = " добавляем ";
                                        populationEeaRow = cr.Data.Base.Ds.Source_data_Population_eea.NewSource_data_Population_eeaRow();
                                        populationEeaRow.id_subject = var.IdSubjNow;
                                        populationEeaRow.year_data = Convert.ToInt16(var.YearNow);
                                        populationEeaRow.id_tax_eea = Convert.ToInt32(var.Taxes_eea[j][1]);
                                        populationEeaRow.population = impData.returnNullFloat(var.InternalTable.Rows[var.IndexRecord][var.Taxes_eea[j][0]], 2);
                                        int pid = checkSubjectPId(var.IdSubjNow);
                                        if (pid > 0)
                                        {
                                            populationEeaRow.pid = pid;
                                        }
                                        cr.Data.Base.Ds.Source_data_Population_eea.AddSource_data_Population_eeaRow(populationEeaRow);
                                    }
                                    if (status == 1)
                                    {
                                        var.Status = " изменяем ";
                                        //populationEeaRow = cr.Data.Base.Ds.Source_data_Population_eea.FindByid(var.CheckedId);
                                        //populationEeaRow.population = impData.returnNullFloat(var.InternalTable.Rows[var.IndexRecord][var.Taxes_eea[j][0]], 2);
                                    }
                                    if (status == 2)
                                    {
                                        var.Status = " удаляем ";
                                        //cr.Data.Base.Ds.Source_data_Population_eea.FindByid(var.CheckedId).Delete();
                                    }
                                    if (status == 3)
                                    {
                                        var.Status = " проверено ";
                                    }
                                }
                            }
 
                        }
 
                        //cr.Data.Base.SourceDataPopulationEeaTableAdapter.Update(cr.Data.Base.Ds.Source_data_Population_eea);
                        //
                        //cr.Data.Base.Ds.AcceptChanges();
                        DataRow[] dRowLev1;
                        //---------------------------------------Ловлю дубли здесь, дублей нет
                        string filter = cr.Data.Base.Ds.Source_data_Population_eea.id_subjectColumn.ToString() + "= 15"+
                        " AND " + cr.Data.Base.Ds.Source_data_Population_eea.year_dataColumn.ToString() + "= 2005" +
                        " AND " + cr.Data.Base.Ds.Source_data_Population_eea.id_tax_eeaColumn.ToString() + "= 1015"; //создаем фильтр
                        dRowLev1 = cr.Data.Base.Ds.Source_data_Population_eea.Select(filter);
                        
//Согласно рекомендациям мс сделал, как написано ниже
base_nalogDataSet.Source_data_Population_eeaDataTable deleteRows = (base_nalogDataSet.Source_data_Population_eeaDataTable)cr.Data.Base.Ds.Source_data_Population_eea.GetChanges(DataRowState.Deleted);
                        base_nalogDataSet.Source_data_Population_eeaDataTable newRows = (base_nalogDataSet.Source_data_Population_eeaDataTable)cr.Data.Base.Ds.Source_data_Population_eea.GetChanges(DataRowState.Added);
                        base_nalogDataSet.Source_data_Population_eeaDataTable modifiedRows = (base_nalogDataSet.Source_data_Population_eeaDataTable)cr.Data.Base.Ds.Source_data_Population_eea.GetChanges(DataRowState.Modified);
                        try
                        {
                            if (deleteRows != null)
                            {
                                cr.Data.Base.SourceDataPopulationEeaTableAdapter.Update(deleteRows);
                            }
                            cr.Data.Base.SourceDataPopulationEeaTableAdapter.Update(cr.Data.Base.Ds.Source_data_Population_eea);
 
                            if (newRows != null)
                            {
                                cr.Data.Base.SourceDataPopulationEeaTableAdapter.Update(newRows);
                            }
                            if (modifiedRows != null)
                            {
                                cr.Data.Base.SourceDataPopulationEeaTableAdapter.Update(modifiedRows);
                            }
                            cr.Data.Base.Ds.AcceptChanges();
                        }
                        catch (Exception ex)
                        {
                        }
                        finally
                        {
                            if (deleteRows != null)
                            {
                                deleteRows.Dispose();
                            }
                            if (newRows != null)
                            {
                                newRows.Dispose();
                            }
                            if (modifiedRows != null)
                            {
                                modifiedRows.Dispose();
                            }
                        }
///////////////////////////////////////////////////////////
                        //
                        cr.Data.Base.SourceDataPopulationEeaTableAdapter.Fill(cr.Data.Base.Ds.Source_data_Population_eea);
                        //--------------------------------Ловлю дубли здесь, дубли есть
                        dRowLev1 = cr.Data.Base.Ds.Source_data_Population_eea.Select(filter);
                        status = -1;
                        break;
                        #endregion ВЭД
                    }
}
TableAdapter создан с помощью дизайнера, все стандартное.
Может, кто уже решал эту проблему, подскажу плз.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.06.2012, 01:04
Ответы с готовыми решениями:

Объявлена война с TableAdapter.Update
Уже битый час с ним бьюсь. Не поддается. { passNO = Convert.ToInt32(textBox4.Text); passSERIAL =...

Формирование Delete и Update запроса для tableAdapter
Добрый день! я формирую insert запрос для tableAdapter'ов(каждый адаптер связан со своей таблицей) таким вот образом: ...

Переопределение запросов TableAdapter-a. Запросы UPDATE и DELETE
Изначально не удавалось отредактировать базу. На форумах нашёл, что неободимо посмотреть свойства TableAdaptera. Посмотрел - и...

2
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,246
13.06.2012, 09:25
у вас случаем dataTable заполняется не руками из кода?
там AcceptChanges() надо вызвать у dt, чтобы применить изменения, а потом уже менять что то
0
8 / 8 / 2
Регистрация: 20.02.2009
Сообщений: 139
13.06.2012, 22:13  [ТС]
Нет, руками в таблицу ничего не заводится.
Данные считываются из екселя, заносятся в DataTable (через DataRow), затем делается команда Update() для TableAdapter исходя из добавленных в DataTable DataRow.
После выполнения Update() записи в таблице БД задваиваются.
С чем это связано не пойму.

Добавлено через 12 часов 27 минут
Затупил с Апдейтами и подчиненными таблицами. Убрал связь и обновил таблицу без задвоений (как изначально было)
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
64
65
                case 1:
                    {
                        #region ВЭД
                        for (var.IndexRecord = indexRowToStart + 1; var.IndexRecord < var.InternalTable.Rows.Count; var.IndexRecord++)
                        {
                            #region проверка значения
                            try
                            {
                                strSubject = var.InternalTable.Rows[var.IndexRecord][0].ToString();
 
                            }
                            catch (System.Exception err)
                            {
                            }
                            var.IdSubjNow = impData.defineParamSubjId(strSubject, cr.Data.Base.Ds.Subjects.subject_nameColumn.ToString());
 
                            #endregion проверка значения
                            for (int j = 0; j < var.Taxes_eea.Count; j++)
                            {
                                if (var.InternalTable.Rows[var.IndexRecord][j] != System.DBNull.Value &&
                                    var.IdSubjNow > 0)
                                {
                                    status = checkImportedData(var.IdSubjNow, var.YearNow, impData.returnNullFloat(var.InternalTable.Rows[var.IndexRecord][var.Taxes_eea[j][0]], 2), var.Taxes_eea[j][1], 1);
                                    if (status == 0)
                                    //Проверяем наличие в базе
                                    {
                                        add = true;
                                        var.Status = " добавляем ";
                                        populationEeaRow = cr.Data.Base.Ds.Source_data_Population_eea.NewSource_data_Population_eeaRow();
                                        populationEeaRow.id_subject = var.IdSubjNow;
                                        populationEeaRow.year_data = Convert.ToInt16(var.YearNow);
                                        populationEeaRow.id_tax_eea = Convert.ToInt32(var.Taxes_eea[j][1]);
                                        populationEeaRow.population = impData.returnNullFloat(var.InternalTable.Rows[var.IndexRecord][var.Taxes_eea[j][0]], 2);
                                        int pid = checkSubjectPId(var.IdSubjNow);
                                        if (pid > 0)
                                        {
                                            populationEeaRow.pid = pid;
                                        }
                                        cr.Data.Base.Ds.Source_data_Population_eea.AddSource_data_Population_eeaRow(populationEeaRow);
                                    }
                                    if (status == 1)
                                    {
                                        var.Status = " изменяем ";
                                        populationEeaRow = cr.Data.Base.Ds.Source_data_Population_eea.FindByid(var.CheckedId);
                                        populationEeaRow.population = impData.returnNullFloat(var.InternalTable.Rows[var.IndexRecord][var.Taxes_eea[j][0]], 2);
                                    }
                                    if (status == 2)
                                    {
                                        var.Status = " удаляем ";
                                        cr.Data.Base.Ds.Source_data_Population_eea.FindByid(var.CheckedId).Delete();
                                    }
                                    if (status == 3)
                                    {
                                        var.Status = " проверено ";
                                    }
                                }
                            }
                            cr.Data.Base.SourceDataPopulationEeaTableAdapter.Update(cr.Data.Base.Ds.Source_data_Population_eea);
                            cr.Data.Base.SourceDataPopulationEeaTableAdapter.Fill(cr.Data.Base.Ds.Source_data_Population_eea);
                            cr.Data.Base.Ds.Source_data_Population_eea.AcceptChanges();
                        }
                        status = -1;
                        break;
                        #endregion ВЭД
                    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.06.2012, 22:13
Помогаю со студенческими работами здесь

Что происходит при выполнении метода TableAdapter.Update()
Задача сохранять запись при переходи на следующую строку в DataGridView. Реализовывать решил в обработчике событий RowValidating, так...

TableAdapter. Метод Update, написанный вручную, автоматически удаляется
в общем проблема заключается в следующем: в xxxDataSet.xsd в одном из tableAdapter'ов созданных автоматически при указании источников...

Не сохраняются изменения в базе данных после запуска метода Update класса TableAdapter
В принципе, проблема изложена в названии темы. Я самоучка, делаю всё так как сказано в учебном пособии (прилагаю его в качестве вложения)...

Как так? или TableAdapter.Update
Всем привет. Вот пишу программу работы с БД. Визуальными инструментами присоединил БД (находится в проекте), поставил DataGridView, пару...

TableAdapter Update не сохраняется последняя строка
Всем привет.В datagridview отображается таблица из БД. В datagridview одна из колонок combobox.Изменения в ней сохраняются с помощью...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru