Evo jednog zanimljivog trika koji ฤe vam pomoฤi u tome da izbegnete eventualne greลกke u vreme izvrลกavanja aplikacije, i to prilikom uvoza podataka u Access. Ukoliko probate da uvezete podatke sa formiranim indeksima, gotovo je sigurno da ฤe se desiti greลกka, a pored toga sam proces uvoza podataka je mnogo brลพi ukoliko uvezene tabele nemaju indekse. Za postizanje maksimalne brzine, potrebno je pre uvoza podataka iz, recimo, tekstualnih fajlova ukloniti indekse iz Access tabela. Nakon uvoza podataka, ponovo ฤemo kreirati indekse uz pomoฤ programskog koda. Sve ovo se deลกava automatski, u jednom paketnom procesu.
Da biste izbegli greลกke, pre uklanjanja i ponovnog rekreiranja indeksa, potrebno je odrediti da li oni (indeksi) uopลกte i postoje. Za ovo odreฤivanje upotrebiฤemo kratku funkciju. Kada funkciji prosledite naziv tabele i naziv indeks-polja, funkcija ฤe vratiti True ukoliko je polje indeksovano, i False ukoliko nije indeksovano.
Public Function Index_Postoji( _
strTable As String, strField As String) As BooleanOn Error GoTo Index_Exists_ERR
Dim dbs As Database
Dim tbl As TableDef
Dim idx As Index
Dim fld As FieldSet dbs = CurrentDb
Set tbl = dbs.TableDefs(strTable)Index_Exists = False
With tbl
For Each idx In tbl.Indexes
For Each fld In idx.Fields
If fld.Name = strField Then
Index_Exists = True
End If
Next
Next
End WithIndex_Exists_EXIT:
Set dbs = Nothing
Exit FunctionIndex_Exists_ERR:
MsgBox Err.Description
Resume Index_Exists_EXIT
End Function
Pratite Krstaricu na www.krstarica.com