С Новым годом! Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
5 / 5 / 3
Регистрация: 15.01.2017
Сообщений: 690

При повторном появлении ошибки обработка ошибки не срабатывает

12.02.2019, 19:15. Показов 1547. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Логика:
- Пользователь. Нажимает кнопку;
- Код . Создаёт "Recordset" "rstStud"(студенты) и "rstGroupStud"(ГруппыСтуденты);
- Код . Цикл. Перебирает "rstStud";
- - Код . Добавить запись в "rstGroupStud";
- - Код . Если запись существует - перейти к следующей записи в цикле;
- - Код . Если запись новая - добавить запись в "rstGroupStud";
Суть: одно нажатие кнопки - добавить одну уникальную запись.

Проблема.
Когда цикл проходит !ИмяСтудента = "Имя Студента 2" в строке ".Update" получаю ошибку.
Ошибка:
"Не удалось внести изменения из-за повторяющихся значений в
индексе, первичном ключе или связях. Измените данные в одном
или нескольких полях, содержащих повторяющиеся значения,
удалите индекс или переопределите его, разрешив
повторяющиеся значения, и повторите попытку."

Т.е. первый раз обработчик ошибок срабатывает нормально, а при повторном срабатывании получаю ошибку.

Вопрос.
Как сделать чтобы код работал согласно описанной логики?

Visual Basic
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
Private Sub btnAddName_Click()
        Dim nameStud As String
        
        Dim rstStud As DAO.Recordset   ' Студенты
        Dim rstGroupStud As DAO.Recordset ' ГруппыСтуденты
        
       Set rstStud = CurrentDb.OpenRecordset("тбл_02_Студенты", dbOpenSnapshot)  'Только просмотр
       Set rstGroupStud = CurrentDb.OpenRecordset("тбл_03_ГруппыСтуденты", dbOpenDynaset)  ' Редактирование
                  
        'Перебор всех записей в наборе
            With rstStud
                Do Until .EOF = True 'Цикл до конца набора
                    nameStud = !ИмяСтудента
                
                ' Обработка ошибки
                    On Error GoTo errend
                    ' Call AddRecordInRstGroupStud(nameStud)
                             With rstGroupStud
                                    .AddNew
                                    'Заполнение полей значениями
                                    !ИДГруппы = Me.ИДГруппыФрм
                                    !ИмяСтудента = nameStud
                                    ' nameStud
                                    .Update
                              End With
                              rstGroupStud.Close
                              Me.фрм_04_ГруппыСтуденты.Requery
                    Exit Sub
errend:
                    .MoveNext
                Loop
            End With
            
            On Error Resume Next
            rstStud.Close
            Set rstStud = Nothing
 
End Sub
Миниатюры
При повторном появлении ошибки обработка ошибки не срабатывает   При повторном появлении ошибки обработка ошибки не срабатывает  
Вложения
Тип файла: zip ErrorRepeat_1.zip (35.2 Кб, 2 просмотров)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.02.2019, 19:15
Ответы с готовыми решениями:

Остановка своей службы при появлении ошибки
Всем привет. Вопрос возник, сам не могу врубиться. Есть служба. protected override void OnStart(string args) { ...

при повторном call валят ошибки
Люди помогите... надежды нету никакой и нигде!!! Нужно написать программу в граф режиме строящую отрезки вот накидал тут один отрезок...

Уже скомпилированный проект выдаёт ошибки при повторном запуске
Доброе время суток! Имеется: .exe-шник и Delphi-проект к нему. В .exe есть небольшой баг, требуется устранить. При попытке...

5
296 / 257 / 68
Регистрация: 18.06.2015
Сообщений: 570
13.02.2019, 09:16
Не совсем понял конечной цели этого кода - добавить всех студентов в группу?
Зачем тогда выходите из процедуры в 28-й строке? При следующем нажатии цикл начинается заново, а такой студент уже есть, уникальный ключ не даст добавить второй раз того же студента в группу.

Кто же ставит метку обработчика ошибки до выхода из цикла?

И такие вещи лучше делать запросом, а не переором рекордсета.

Добавлено через 11 минут
А если вам нужно за раз добавить только одного студента, где проверка, что студент из текущей записи студентов уже существует в группе? "Проверять" с помощью попытки вставки и обработки ошибки также плохая практика. Если уж хотите сделать именно так (в учебных целях, как я понимаю), то после возникновения ошибки ее нужно обработать с помощью Resume, Resume Next или хотя бы Err.Clear

Добавлено через 9 минут
Типа вот так:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
            rstGroupStud.Close
            Me.фрм_04_ГруппыСтуденты.Requery
            Exit Sub
NextStud:
            .MoveNext
        Loop
    End With
            
    On Error Resume Next
    rstStud.Close
    Set rstStud = Nothing
errend:
    Resume NextStud
End Sub
Но вообще я бы код переписал, плоховат.
1
459 / 246 / 15
Регистрация: 29.10.2014
Сообщений: 1,084
13.02.2019, 09:25
Цитата Сообщение от Soft17 Посмотреть сообщение
!ИмяСтудента = nameStud
это из какого набора? в предыдущ строках два With - я еще так не пробовал из соображен безопасности.
0
296 / 257 / 68
Регистрация: 18.06.2015
Сообщений: 570
13.02.2019, 09:33
Цитата Сообщение от commun Посмотреть сообщение
это из какого набора?
rstGroupStud конечно. Вложенные With вполне допустимы, но их лучше избегать для лучшей читаемости программы, максимум короткие вставки на несколько строк, типа этой.
1
459 / 246 / 15
Регистрация: 29.10.2014
Сообщений: 1,084
13.02.2019, 10:21
Цитата Сообщение от MrShin Посмотреть сообщение
Вложенные With вполне допустимы
Не знал. Ну пусть все таки попробует изменить имя поля на ИмяСтудента1.
0
Эксперт MS Access
 Аватар для Eugene-LS
12058 / 5843 / 1492
Регистрация: 05.10.2016
Сообщений: 16,432
13.02.2019, 12:28
Soft17, с моей скромной точки зрения, у вас всё не правильно.
Нет индексов в таблицах (и уникальных в т.ч.)
Нет схемы данных.
И ещё:
Группа объединяет некоторое кол-во студентов.
Значит: в таблице "тбл_02_Студенты" должно быть поле связи с группой в которой студент учится на данный момент.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.02.2019, 12:28
Помогаю со студенческими работами здесь

Обработка ошибки при не верном расширении
Всем привет. Стоит задача вместо ошибок 404 и тп перенаправлять пользователя на определенную страницу. Все вроде довольно просто В...

Обработка ошибки при не существующем инклуде
При переходе по страницам, у меня отправляются гет запросы типа site.ru/?do=page Вместо page пишется название реальной страницы в папке...

Обработка ошибки при разрыве связи
Подскажите пожалуйста. Есть програмка которая обращается к другому устройству через COM порт. Но если это устройство отсоеденить от COM...

Обработка ошибки при потере COM порта
Добрый день! Пока не приходилось сталкиваться с обработкой ошибок, поэтому обращаюсь к вам. Есть программа, которая работает с COM...

Обработка ошибки при вызове несуществующего макроса
Добрый день. Извеняюсь если что не так Имя запускаемого макроса формируется динамически в цикле, и нет проблем до момента, пока в...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru