...
On Error Goto ERROR
OPEN:
Set Db = OpenDatabase(путь, True, False, "MS Access")
...
...
ERROR:
If Err.Number = 3356 Then
Sleep
Resume OPEN
End IF
MsgBox Err.Description
...
Проверка занятости базы данных с использованием DAO
В нескольких процедурах есть подключение к базе:
Dim Db As Database
Dim r As Recordset
Private Sub вставить_в_базу()
Set Db = OpenDatabase(путь, True, False, "MS Access")
Set r = Db.OpenRecordset("таблица", dbOpenDynaset)
здесь тело процедуры
и закрытие базы
r.Close
Set r = Nothing
Db.Close
Set Db = Nothing
End Sub
некоторые процедуры обрабатываются 3-4 секунды. Пока с книгой работали два человека, да еще пару раз в день, проблем не было. А сейчас, вдруг неожидано, проект получил актуальность, и с ним стало работать сразу несколько пользователей, и довольно часто. Что привело к периодическому сталкиванию пользователей при обращении к базе. Выскакивает ошибка 3356 с предупреждением, что база данных занята каким то пользователем.
Как, перед открытием базы "Set Db = OpenDatabase(путь, True, False, "MS Access")", проверить занятость базы, и в случае занятости подвесить код секунды на три, и снова повторить проверку занятости?
просто пытайся открыть, и проверяй код ошибки если возникнет