ОБСУЖДЕНИЕ

Как взять Unid самого главного родителя?

8 ответов 5,1 тыс.
AI-выжимка обсуждения скоро

Краткие тезисы обсуждения со ссылками на ключевые ответы появятся здесь.

Автор темы
Доброго времени суток!
Как взять unid самого главного родителя если неизвестно заранее количество ступеней в иерархии?

рекурсия?
спасибо!
 
Не обязательно рекурсия.
Обычным циклом(While..Wend) можно.
 
while doc.IsResponse
set doc = db.GetDocumentByUNID( doc.parentDocumentUNID )
wend

это я на скорую руку написал
doc - NOtesDocument
db - NOtesDatabase
 
еще вот вопрос назрел, если так
while doc.IsResponse
set doc = db.GetDocumentByUNID( doc.parentDocumentUNID )
wend
то как проверить случаи несушествования документов? ссылка на родителя есть, а самого родителя нету?
спасибо!
 
Код:
Function GetDocByUNID(db As NotesDatabase, doc As NotesDocument, UNID As String) As Boolean
On Error Goto Errh

GetDocByUNID = False

If db Is Nothing Then Exit Function
If Trim$(UNID) = "" Then Exit Function

On Error Resume Next
Set doc = db.GetDocumentByUNID(UNID)
On Error Goto Errh

If Not doc Is Nothing Then GetDocByUNID = True

Exit Function
Errh:
Call ErrHandler
Exit Function
End Function
 
спасибо!!!!! :(

а в цикле Do While doc.IsResponse ...
наверно, проверка на валидность уже не нужна, т.к.
она уже присутствует GetDocByUNIDA:
If Not GetDocByUNIDA.IsValid Then Set GetDocByUNIDA = Nothing
 

Статистика тем

Создано
oxystile,
Последний ответ от
morpheus,
Ответы
8
Просмотры
5 107