Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 04.06.2007
Сообщений: 81

Рекордсет и транзакции, вопрос.

19.05.2008, 04:19. Показов 553. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Жил-был простой работающий код:
Code
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
 
 
'=====================================================================
private sub Some_Procedure()
        
       .............
       .............
 
        Dim ii As Integer
        Dim rsTDS As Recordset ' сегодняшние продажи ToDaySales
        Set rsTDS = dbArticules.OpenRecordset('Today_sales')
        For ii = 0 To UBound(SD.CheckDatas(nKassa - 1).CheckNames) - 1
           rsTDS.AddNew
           Set rs = dbArticules.OpenRecordset('select * from All_records where name='' & SD.CheckDatas(nKassa - 1).CheckNames(ii) & ''')
           With rs
            .Edit
            .Fields('Amount_V_otdele_1') = .Fields('Amount_V_otdele_1') - CDbl(SD.CheckDatas(nKassa - 1).CheckAmounts(ii))
            .Update
           rsTDS.Fields('Skidka') = 0
           rsTDS.Fields('dep') = .Fields('dep')
           rsTDS.Fields('name') = .Fields('name')
           rsTDS.Fields('Kassa_name') = .Fields('Kassa_name')
           rsTDS.Update
           End With
         Next ii
       ..................
       ...................
end sub
'======================================================================
 
 
   Но захотелось неумному программисту защитить его транзакциями
Вот таким макаром, в результате он загнулся очень странным образом:
 
'======================================================================
option Explicit  
dim wrkDefault as Workspace
'-----------------------------------------------------------------------------
Private Sub Form_Load() 
  .............
  ..........
Set wrkDefault = dao.DBEngine.Workspaces(0)
Set dbArticules = wrkDefault.OpenDatabase(App.Path & '/Sclad.mdb')
  ............
  ............
end sub
'-----------------------------------------------------------------------------
private sub Some_Procedure()
        
       .............
       .............
       wrkDefault.BeginTrans
       
 
        Dim ii As Integer
        Dim rsTDS As Recordset ' сегодняшние продажи ToDaySales
        Set rsTDS = dbArticules.OpenRecordset('Today_sales')
        For ii = 0 To UBound(SD.CheckDatas(nKassa - 1).CheckNames) - 1
           rsTDS.AddNew
           Set rs = dbArticules.OpenRecordset('select * from All_records where name='' & SD.CheckDatas(nKassa - 1).CheckNames(ii) & ''')
           With rs
 
 
 
            .Edit  '///// <--------------теперь он вот здесь останавливается
                   '  и говорит'Object invalid or no longer exists'
                   ' хотя выполняемая в ImmediateWindow строка говорит следующее: 
                   '(rs is Nothing)=False 
 
 
            .Fields('Amount_V_otdele_1') = .Fields('Amount_V_otdele_1') - CDbl(SD.CheckDatas(nKassa - 1).CheckAmounts(ii))
            .Update
           rsTDS.Fields('Skidka') = 0
           rsTDS.Fields('dep') = .Fields('dep')
           rsTDS.Fields('name') = .Fields('name')
           rsTDS.Fields('Kassa_name') = .Fields('Kassa_name')
           rsTDS.Update
           End With
         Next ii
       
 
  
       wrkDefault.CommitTrans
       ..................
       ...................
end sub
'-----------------------------------------------------------------------------------------
Насколько я понимаю, открываемый внутри транзакции Recordset
открывается с пустой коллекцией Fields

0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.05.2008, 04:19
Ответы с готовыми решениями:

Вопрос про транзакции и хранимые процедуры
Здравствуйте! У меня вот такой вопрос. Есть в SQL Server 2000 две таблицы. В №1 содержатся...

Транспонировать рекордсет
Люди, здравствуйте. Есть запрос, который возвращает список магазинов. Его надо вставить на лист....

пустой рекордсет
Dim RST as RecordSet Set RST = CurrentDb.OpenRecordset(&quot;select * from node n where n.node_id = &quot; &amp;...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.05.2008, 04:19
Помогаю со студенческими работами здесь

Множественный рекордсет из ХП
Добрый день! Господа, кто нибудь сталкивался с такой проблемой: Есть ХП (код ниже), которая...

Рекордсет ошибка 7965
Есть файл с формами, назовем его первый, в ней есть рекордсет rs.Open strSQL, Cn, adOpenDynamic,...

Не работает рекордсет на гриде
Народ, привет! Гляньте, плиз, вот это: Dim cn As ADODB.Connection Dim rs As ADODB.Recordset Set...

Как заполнить рекордсет?
Люди, здравствуйте. У меня бугурт. Я не могу заполнить рекордсет значениями. Тут прочитал,...

Метод, возвращающий рекордсет
у меня есть класс и в нем методы типа Public Function getCity(regionCode As String, areaCode As...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита табличной части. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru