0 / 0 / 0
Регистрация: 11.08.2008
Сообщений: 35

ADO, сохранение обновленной записи

12.08.2008, 20:03. Показов 1007. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Суть:
При вводе в базу новой записи - тратиться достаточно много времени (18 полей), проще открыть ранее внесенную и немного изменить ее. Все бы хорошо но след. код - обновляет исправленную запиь а не сохраняет ее как новую. Подскажите - плз как создавать при сохранении новые записи.

Code
1
2
3
4
5
Private Sub cmdSave_Click()
rs.UpdateBatch adAffectAll
            If mbAddNewFlag Then
                rs.MoveLast
End Sub
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.08.2008, 20:03
Ответы с готовыми решениями:

Ошибка в ADO, Сохранение записи
Здравствуйте... Вопрос в конце кода... Private Sub Сохранить(Код as Long) On Error GoTo bay Dim RS As ADODB.Recordset If Not...

ADO тормозит при добавлении записи.
У меня два рекордсета, один для отображения данных в таблице rcsR, второй для записи в базу rcsW. Оба нацелены на одну таблицу. Ситуация...

Как удалить все записи с ADO?
Имеется ситуация, когда надо полностьбю из таблицы удалить все записи... Как сделать, непонятно.... обычным <code> With...

4
0 / 0 / 0
Регистрация: 29.07.2008
Сообщений: 5
13.08.2008, 07:24
Нет, нет и нет.
Никогда так не получится! Если полей много и ты не уверен и времени это занимает такую большую кучу, то я бы сделал транзакцию.
Перед началом добавления записи BeginTrans, а тосле окончания добавления CommitTrans. Если что-то не так, то транзакцию можно будет отменить.
0
0 / 0 / 0
Регистрация: 11.08.2008
Сообщений: 35
13.08.2008, 11:09  [ТС]
А можно по подробнее? Если конечно это реально - пример кода. Я не так давно занимаюсь базами VB, так, что это для меня темный лес...
0
0 / 0 / 0
Регистрация: 29.07.2008
Сообщений: 5
14.08.2008, 20:15
Ну в данном случае транзакции не помогут. Их применяют если нужны множественные обновления зависящие друг от друга. Например, ты обновляешь по одной записи в разных таблицах. Для этого начинаем транзакцию и далее как обычно и метода Update тоже вызываем, вот только при вызове этих Update Jet-машина физически не обновляет записи до тех пор, пака ты не закочишь транзакцию. Если при обновлении одной из записи произошла ошибка то вторая для тебя не будет иметь смысл (ну бывают такие зависимые записи) и в этом случае нужно отменить транзакцию и все вернется на место. А без транзакции пришлось бы восстановливать старую запись.
0
0 / 0 / 0
Регистрация: 11.08.2008
Сообщений: 35
14.08.2008, 20:23  [ТС]
Метод который предложил Solovyov логически представляется наиболее правильным, сначала я думал сделать еще одну форму для просмотра полученных данных и передать записи между полямив двух разных формах, но это как то тяжеловесно и не факт, что заработает. Плюс для оператора путаница возникает.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.08.2008, 20:23
Помогаю со студенческими работами здесь

Как определить нахождение записи в ADO?
В DAO (при поиске Recordset.FindFirst) есть такое своиство как Recordset.Nomatch и оно равно False при нахождении записи и равно True...

ADO не успевает прочитать записи. Как бороться?
Set CN = New ADODB.Connection CN.Open 'Driver=Microsoft Access Driver (*.mdb); DBQ=' & App.Path & 'Data_b.mdb' Set RS = New...

Вывод обновленной записи через ajax
Всем доброго дня. У меня есть таблица в ней 3 столбца первый столбец статус 1, второй статус 2, третий статус 3. В базе данных есть таблица...

Как сделать select и update одним запросом что бы потом узнать id этой обновленной записи
Всем привет друзья! Перейду сразу к сути! Много рылся в интернете по данному вопросу и нашёл только варианты, как сделать update и select...

Повторяющиеся записи в ado
при попытке вставить запись, которая уже имеется в наборе данных вылетает ошибка Stack OverFlow. Как лучше обработать такую ошибку,...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера 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