Форум программистов, компьютерный форум, киберфорум
HCL Notes: Программирование
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.79/24: Рейтинг темы: голосов - 24, средняя оценка - 4.79
0 / 0 / 0
Регистрация: 30.11.2007
Сообщений: 410

При открытии документов пересчитывается вид

15.01.2016, 20:46. Показов 4944. Ответов 6
Метки нет (Все метки)

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

есть отчет под вэбом.
Строит его агент, который ползет по виду навигатором и вычисляем определенные значения,
НО! если в этот момент открываются документы из этой базы то вид вероятно как то пересчитывается и часть строчек не доступно агенту. поэтому значения отчета каждый раз разные...

ставил в виде настройку Refresh: Manuial + restart server
не помогает.

как можно обойтись только переделав вид?
потому что отчет очень большой и переписывать его на db.Search = убица ап стену.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.01.2016, 20:46
Ответы с готовыми решениями:

Задержка при открытии документов
Приветствую всех. такая проблема. машина с доменной группе, при открытии документа, любого, независимо от его содержимого наблюдается...

Ошибка XDTO при открытии документов
Добрый день, столкнулся с проблемой при открытии документов у пользователей на терминальном сервере выдает ошибку. Кеши у...

Вид формы при открытии
Что надо изменить в свойствах формы, чтобы при открытии она автоматически показывала: 1) новую запись 2) последнюю запись и чтобы...

6
0 / 0 / 0
Регистрация: 13.10.2005
Сообщений: 848
15.01.2016, 23:05
попробуйте это
0
0 / 0 / 0
Регистрация: 30.11.2007
Сообщений: 410
16.01.2016, 10:36
Спасибо!
выручила строка: view.AutoUpdate = False
0
0 / 0 / 0
Регистрация: 13.10.2005
Сообщений: 848
16.01.2016, 13:51
я таки советую присмотреться к


LotusScript
1
2
3
4
5
6
7
8
9
  enable cache for max buffering
 
nav.BufferMaxEntries = 400
 
Msgbox  "View: " + view.Name + " 10000 entries, Cache: " + Cstr(nav.BufferMaxEntries)
 
if we are not interested in the number of children, we can go a little faster
 
nav.EntryOptions = Vn_entryopt_nocountdata
весьма полезно для перформанса
0
0 / 0 / 0
Регистрация: 23.08.2008
Сообщений: 6,252
17.01.2016, 12:43
по ссылке не понял пассажа

LotusScript
1
2
3
4
5
6
 Set view = db.getView("$All")
Set nav = view.createViewNav()
do not do AutoUpdates
view.AutoUpdate = False
create a ViewNavigator
Set nav = view.createViewNav()
обшибся автор, видать бадн-бадн получился
0
0 / 0 / 0
Регистрация: 25.12.2010
Сообщений: 246
19.01.2016, 10:47
Для закрепления, видимо.
Это что, я как-то такое видел:

Set doc=doc
0
0 / 0 / 0
Регистрация: 23.08.2008
Сообщений: 6,252
08.03.2016, 17:52
базовый класс класс созданный по мотивам

LotusScript
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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
%REM
*********************************************
Class ViewNav
Description: creates view Navigator
only string key accepted, as first sorted column value
%END REM
Class ViewNav As ErrorHandler
Private logDoc As NotesDocument
Private columns List As Integer
Private db As NotesDatabase
Private view As NotesView
Private key As String
Private nav As NotesViewNavigator
Private lastAU As Boolean last autoupdate state
Private first As NotesViewEntry
Private last As NotesViewEntry
Private debug As Boolean
Private safe As Boolean for safe update (dont replace "existing" value)
 
%REM
*--------------------------------------------
Sub New
Description: Comments for Sub
%END REM
Sub New(viewName As String, key As String)
Dim routineName As String
routineName="New"
On Error GoTo ErrH
your code here
Dim ses As New NotesSession
Set me.db=ses.Currentdatabase
Set me.logDoc=me.db.CreateDocument
Call me.logDoc.Replaceitemvalue({form}, {log})
Set me.rtTrace=me.logDoc.Createrichtextitem({body})
Call me.logDoc.Computewithform(False, False)
me.key=key
Set view=db.Getview(Viewname)
me.lastAU=me.view.AutoUpdate
me.view.AutoUpdate= False
me.view.Refresh
Dim entry As NotesViewEntry
Set entry=view.Getentrybykey(me.key, true)
Dim NEC As NotesViewEntryCollection
Print {Class:} TypeName(Me) {->} {Key:} me.key
Set NEC=view.Getallentriesbykey(me.key, true)
Set entry=NEC.Getfirstentry()
If entry Is Nothyng Then
Print {Class:} TypeName(Me) {->} {First Entry Is Nothyng}
Set nav=view.Createviewnav()escape error if key doesnt match any entries
Else
Print {Class:} TypeName(Me) {->} {Entries Count} NEC.Count
Set me.nav=view.Createviewnavfrom(entry)
https://www-10.lotus.com/ldd/ddwiki.nsf/dx/Fast_Retrieval_of_View_Data_Using_the_ViewNavigator_Cache
nav.BufferMaxEntries = NAV_BUF
nav.EntryOptions = Vn_entryopt_nocountdata
Set me.first=entry
Set entry=NEC.Getlastentry()
Set me.last=nav.Getentry(entry)
ForAll col In me.view.Columns
Dim tmp As NotesViewColumn
Set tmp=col
me.columns(tmp.ItemName)=tmp.Position-1
End ForAll
End If
Quit:
Exit Sub
ErrH:
Error Err, RaiseError
Resume Quit
End Sub
 
%REM
*--------------------------------------------
Property Set IsDebug
Description: Comments for Property Set
%END REM
Property Set IsDebug As Boolean
Dim routineName As String
routineName="IsDebug"
On Error GoTo ErrH
your code here
me.debug=IsDebug
Quit:
Exit Property
ErrH:
Error Err, RaiseError
Resume Quit
End Property
%REM
*--------------------------------------------
Function GetFirst
Description: Comments for Function
%END REM
Function GetFirst() As NotesViewEntry
Dim routineName As String
routineName="GetFirst"
On Error GoTo ErrH
your code here
Set GetFirst=me.first
Quit:
Exit Function
ErrH:
Error Err, RaiseError
Resume Quit
End Function
 
%REM
*--------------------------------------------
Function GetPrev
Description: Comments for Function
%END REM
Function GetPrev(entry As NotesViewEntry) As NotesViewEntry
Dim routineName As String
routineName="GetPrev"
On Error GoTo ErrH
your code here
If entry.Getposition(POS_SEP) = me.first.Getposition(POS_SEP) Then GoTo Quit
Set GetPrev=nav.Getprev(entry)
If Me.GetPrev.Columnvalues(0)<>key Then Set GetPrev=NOTHING
Quit:
Exit Function
ErrH:
Error Err, RaiseError
Resume Quit
End Function
 
%REM
*--------------------------------------------
Function GetNext
Description: Comments for Function
%END REM
Function GetNext(entry As NotesViewEntry) As NotesViewEntry
Dim routineName As String
routineName="GetNext"
On Error GoTo ErrH
your code here
If entry.Getposition(POS_SEP) = me.last.Getposition(POS_SEP) Then GoTo Quit
Set GetNext=me.nav.Getnext(entry)
If Me.GetNext.Columnvalues(0)<>me.key Then Set GetNext=Nothyng
Quit:
Exit Function
ErrH:
Error Err, RaiseError
Resume Quit
End Function
 
%REM
*--------------------------------------------
Sub Get HashMap
Description: return List Array
%END REM
Sub GetHashMap(lst List As Variant)
Dim routineName As String
routineName="HashMap"
On Error GoTo ErrH
your code here
HashMap=
Quit:
Exit Sub
ErrH:
Error Err, RaiseError
Resume Quit
End Sub
 
Sub Delete()
If Not me.view Is Nothyng Then
me.view.Refresh
me.view.Autoupdate=me.lastAU
End If
End Sub
 
%REM
*--------------------------------------------
Sub ShowLog
Description: Comments for Sub
%END REM
Sub ShowLog
Dim routineName As String
routineName="ShowLog"
On Error GoTo ErrH
your code here
Dim wks As New NotesUIWorkspace
me.rtTrace.Update
Call wks.Editdocument(True, me.logDoc)
Quit:
Exit Sub
ErrH:
Error Err, RaiseError
Resume Quit
End Sub
 
%REM
*--------------------------------------------
Function UpdateByHashMap
Description: update "collection" according HashMap
all additional documents will be added
%END REM
Function UpdateByHashMap(vnav As ViewNav)
Dim routineName As String
routineName="UpdateByHashMap"
On Error GoTo ErrH
your code here
If Not vnav IsA TypeName(Me) Then _
Error 1024, CM_NAVTYPEMISMATCH &TypeName(Me) &{/} &TypeName(vnav)
 
Dim lst List As Variant
Call Me.GetHashMap(lst)
Dim entry As NotesViewEntry
Set entry=vnav.GetFirst()
Do While Not entry Is Nothyng
Dim tmpkey As String
tmpkey=entry.Columnvalues(vnav.GetKeyValueCol())
If IsElement(lst(tmpkey)) Then
If vnav.UpdateValues(lst(tmpkey), entry) Then
Call entry.Document.Save(True, False, False)
End If
Erase lst(tmpkey)
End If
Set entry=vnav.GetNext(entry)
Loop
ForAll m In lst
Dim doc As NotesDocument
Set doc=vnav.CreateDocument(ListTag(m),m)
If Not doc Is Nothyng Then
SetType doc
Call doc.Save(True, False, False)
End If
End ForAll
UpdateByHashMap=
Quit:
Exit Function
ErrH:
Error Err, RaiseError
Resume Quit
End Function
 
%REM
*--------------------------------------------
Function GetKeyValue
Description: return Index for key column
%END REM
Function GetKeyValueCol() As Integer
Dim routineName As String
routineName="GetKeyValue"
On Error GoTo ErrH
your code here
GetKeyValueCol=
Quit:
Exit Function
ErrH:
Error Err, RaiseError
Resume Quit
End Function
 
%REM
*--------------------------------------------
Function CreateDocument
Description: Comments for Function
%END REM
Function CreateDocument(keyfld As String, values)
Dim routineName As String
routineName="CreateDocument"
On Error GoTo ErrH
your code here
CreateDocument=
Quit:
Exit Function
ErrH:
Error Err, RaiseError
Resume Quit
End Function
 
%REM
*--------------------------------------------
Function SetType
Description: Comments for Function
%END REM
Function SetType(doc As NotesDocument)
Dim routineName As String
routineName="SetType"
On Error GoTo ErrH
your code here
SetType=
Quit:
Exit Function
ErrH:
Error Err, RaiseError
Resume Quit
End Function
%REM
*--------------------------------------------
Property Set IsSafe
Description: Comments for Property Set
%END REM
Property Set IsSafe As Boolean
Dim routineName As String
routineName="IsSafe"
On Error GoTo ErrH
your code here
me.safe=IsSafe
Quit:
Exit Property
ErrH:
Error Err, RaiseError
Resume Quit
End Property
 
%REM
*--------------------------------------------
Function UpdateValues
Description: assign nev values to entry
%END REM
Function UpdateValues(values, entry As NotesViewEntry) As Boolean
Dim routineName As String
routineName="UpdateValues"
On Error GoTo ErrH
your code here
UpdateValues=
Quit:
Exit Function
ErrH:
Error Err, RaiseError
Resume Quit
End Function
End Class


--- Добавлено 9 мар 2016. Первое сообщение размещено 9 мар 2016 ---

логирование и обработку ошибок - это по собственным желаниям


--- Добавлено 9 мар 2016 ---

много ошметок от затачивания под задачу - лень было выковыривать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.03.2016, 17:52
Помогаю со студенческими работами здесь

Обработка ошибок при открытии документов Microsoft Office
Set Document = Excel.Workbooks.Open(fileName) если документ не откроется - как обработать ошибку?

При открытии документа не должны разворачиваться окна др. документов
ОС Windows 2007, MS Office Word 2007. Подскажите, можно ли как-то настроить Word, чтобы при открытии файла *.docx не разворачивались бы...

Как настроить вид IE при открытии новой страницы из ASP?
Как настроить вид IE при открытии новой страницы из ASP, т.е. убрать строку состояния, адресную строку, кнопки и развернуть на полный...

При открытии документов ms office 2003 кликая по ним комп зависат минут на 5, потом их открывает
При открытии документов ms office 2003 кликая по ним комп зависат минут на 5, потом их открывает. Если открыть сам office а из него...

Нарушение форматирования документов word 2010 при открытии в word 2013
Здравия коллеги! Столкнулся с такой проблемой у человека W8+office2013 всё легальное, документы от офиса 2010 криво открываются, все!...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
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