Проблема с работой в рекодсете

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Проблема с работой в рекодсете

Сообщение Чудик » 13.03.2005 (Вс) 15:47

В цикле такая часть кода:
Код: Выделить всё
    rs.AddNew
    rs.Fields(0) = frmPrihod.MSHFlexGrid1.TextMatrix(MyRow, 1)
    rs.Fields(1) = frmPrihod.txtPrihod.Text
    rs.Fields(3) = PrihodSum
    rs.Fields(2) = a + PrihodSum
    rs.Fields(8) = s1
    rs.Fields(10) = s2
    rs.Fields(12) = b
    rs.Update

rs2.MoveLast
Do While Not rs2.BOF
    If rs.Fields(0)= rs2.Fields(0) Then
        rs2.Edit
        rs2.Fields(5) = rs2.Fields(5) + PrihodSum
        rs2.Update
        GoTo MyDA
    End If
    rs2.MovePrevious
Loop
MyDA:

в начале все хорошо работает, но при достижении n-ого раза после rs.Update значение rs.Fields(0) просто слетает (выдает ошибку отсутствия таковой записи в рекодсете). В построчном выполнении кода так и видно:
до rs.Update rs.Fields(0)="AAA"
после rs.Update rs.Fields(0)=""
Отчего такое может быть? Что вообще может происходить?
Век живи - век учись!
www.detal-plast.narod.ru

Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Сообщение Чудик » 13.03.2005 (Вс) 21:37

В принципе, я так и сделал. Просто уж больно интересно от чего такое явление и как его можно избежать.
Век живи - век учись!
www.detal-plast.narod.ru

Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Сообщение Чудик » 14.03.2005 (Пн) 8:17

Хочешь сказать, что если я открою две базы Access на одном компе, то периодически в одну из копий я не смогу записывать или изменять данные?
Век живи - век учись!
www.detal-plast.narod.ru

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 14.03.2005 (Пн) 9:27

Вообще-то эту задачу можно было бы решить исключительно SQL-запросом (UPDATE Table2 SET Field5 = Field5+123 WHERE Field0 = 234).
А по теме... Как открыт рекордсет (тип блокировки)?
Попробуй UpdateBatch.
Lasciate ogni speranza, voi ch'entrate.

Andrey Fedorov
Член-корреспондент академии VBStreets
Член-корреспондент академии VBStreets
 
Сообщения: 3287
Зарегистрирован: 21.05.2004 (Пт) 9:28
Откуда: Москва

Сообщение Andrey Fedorov » 14.03.2005 (Пн) 11:10

Чудик писал(а):Хочешь сказать, что если я открою две базы Access на одном компе, то периодически в одну из копий я не смогу записывать или изменять данные?


Да нет, не в этом дело.
Фиг Вам! - Сказал Чебурашка, обгладывая Крокодила Гену...

Andrey Fedorov
Член-корреспондент академии VBStreets
Член-корреспондент академии VBStreets
 
Сообщения: 3287
Зарегистрирован: 21.05.2004 (Пт) 9:28
Откуда: Москва

Re: Проблема с работой в рекодсете

Сообщение Andrey Fedorov » 14.03.2005 (Пн) 11:15

Чудик писал(а):В цикле такая часть кода:
в начале все хорошо работает, но при достижении n-ого раза после rs.Update значение rs.Fields(0) просто слетает (выдает ошибку отсутствия таковой записи в рекодсете). В построчном выполнении кода так и
...
Отчего такое может быть? Что вообще может происходить?


Значит в rs2 ты находишься на EOF или BOF - точнее отсюда невидно...
Фиг Вам! - Сказал Чебурашка, обгладывая Крокодила Гену...

Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Сообщение Чудик » 14.03.2005 (Пн) 23:07

alibek писал(а):А по теме... Как открыт рекордсет (тип блокировки)?
Попробуй UpdateBatch.

Параметры БД:
блокировка по умолчанию - отсутствует;
режим открытия по умолчанию - общий доступ.
И что такое UpdateBatch?

Andrey Fedorov, не пойму как я могу находиться в EOF или BOF в той части кода, который был приведен? Ведь, получается, что при нахождении какой-то записи в рекодсете, я ее пытаюсь изменить, - не может же операция сравнения выполняться на EOF/BOF.

Note:
При одноразовом цикле, вроде бы, нет проблем выполнения. Проблема имеет место в том случае когда указанный код крутиться в цикле несколько раз.
Век живи - век учись!
www.detal-plast.narod.ru

Andrey Fedorov
Член-корреспондент академии VBStreets
Член-корреспондент академии VBStreets
 
Сообщения: 3287
Зарегистрирован: 21.05.2004 (Пт) 9:28
Откуда: Москва

Сообщение Andrey Fedorov » 15.03.2005 (Вт) 8:12

Andrey Fedorov, не пойму как я могу находиться в EOF или BOF в той части кода, который был приведен? Ведь, получается, что при нахождении какой-то записи в рекодсете, я ее пытаюсь изменить, - не может же операция сравнения выполняться на EOF/BOF.


Может. Так как данной записи в базе может уже и не быть (так как была изменена одним из предыдущих апдейтов). А в Recordset-e она еще есть.

Ты бы это... Чтобы было проще определить что у тебя за ошибка сделал бы парочку простейших табличек в mdb-шке (или скрипт на создание табличек в базе SQL, если работаешь с ним), ну и маленький проектик показывающий ошибку. И все это, запаковав, приложил к письму. Тогда и разобрались бы с ним в два счета... А так приходится большей частью гадать...
Фиг Вам! - Сказал Чебурашка, обгладывая Крокодила Гену...


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 17

    TopList