Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

VBA Access dbopendynaset vs dbopentable

Tipp Entwicklung VB for Applications

Mitglied: J0j0

J0j0 (Level 1) - Jetzt verbinden

08.07.2009, aktualisiert 06.08.2010, 11847 Aufrufe, 1 Kommentar

Was ist der Unterschied zwischen dynaset und opentable in VBA mittels access!
Problem mit table locks(maxlocksperfile)

Hallo zusammen.

ich habe eine Problem mit VB in MS Access...!

Bisher habe ich einen MAXLOCKSPERFILE Error bekommen,
wenn ich ein recordset via Set db= currentdb oder via DBEngine.Opendatabase(,true) bekommen.
Das Recordset habe ich mit dbopendynaset geöffnet.

Ich hab das Problem mit dem temp hochsetzen von MaxLocksPerFile umgehen können.
Das ist meiner Ansicht nach keine saubere Lösung, da ich exklusiv User bin!
Ich habe nun von dbopendynaset auf dbopentable umgestellt und voila es funktioniert ohne tablelock error!

Woran liegt das? Kann es sein das dbopendynaset eine riesen tabelle erstellt, da ich ja auch edits darauf ausführe?

Was genau ist der Unterschied zwischen opentable und dynaset?
Bisher habe nich noch nichts gefunden.

Vielen Dank!



** Wer wissen will wie das MaxLocksPerFile hochgesetzt wird...:
1. Variante:
DB Exklusive öffnen (Kein Multiuser mehr möglich)
Ändere "Set db = CurrentDb" auf:
Set db = DBEngine.OpenDatabase("F:\Test\testBE.mdb", True)
2. Variante Dauerhaft MaxLocks hochsetzen:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Jet 4.0
(Standart 9500)
3. Variante temporär für die aktuelle Sitzung
DBEngine.SetOption dbMaxLocksPerFile, 15000
Mitglied: J0j0
06.08.2010 um 12:53 Uhr
Da sich bisher noch niemand dazu äußern konnte, beschreibe ich jetzt meine Erfahrungen.

Zuerst zu dem Unterschied von dbopentable und dbopendynaset.

dbopentable ist ein direkter Zugriff auf die Tabelle.
Das bedeutet Sie wird real geöffnet und bei falschen Accesseinstellungen (Lock whole table), kann immer nur ein einzelner die Tabelle öffnen.
Auch ist dbopentable sehr viel Langsamer, da sich Access immer die gesamten Daten zieht.

dbopendynaset ist sehr viel schneller und für den normalen gebrauch sollte man das eigentlich IMMER verwenden.
Access erstellt sich ein Abbild der Tabelle, allerdings werden keine daten geladen, ausser Anzahl der tupel sowie einen eindeutigen Zeiger auf einen tupel.
Wenn ich nun Daten editieren möchte ruft Access erst dann diese Daten auch ab und erfahrt auch dann erst ob der Datensatz noch vorhanden ist oder jemand anderes/etwas anderes ihn gelöscht hat.

So kann es zu dead locks kommen, da man nur einen Ordnungsgemäßen betrieb mit einem guten Errorhandling erreicht.
Ein Beispiel:
Ist Datensatz vorhanden?

Wenn ja -> Editieren/Löschen

Wenn nein --> mache nichts

Das funktioniert nur wenn ich alleine auf der Datenbank arbeite.
Ist noch jemande anderes unterwegs muss ich mir den Datensatz sperren oder ein Errorhandling basteln.
Das gibt natürlich performance Vorteile, wenn man bei einer Accessdatenbank überhaupt von Performance sprechen kann.
If-Abfragen fallen weg!

Ändere Datensatz

Fehler? --> Errohandling (zum Beispiel überprüfen ob und warum der Datensazu vorhanden ist)

Kein Fehler --> Datensatz geändert

Da es in einer 2 Mann umgebung mit 100.000 Datensätzen unwahrscheinlich ist das beide genau gleichzeitig einen Datensatz verarbeiten,
arbeitet Access damit schneller.

VORSICHT:
Da sich dbopendynaset immer ein Abbild der Datenbank anlegt, sollte man in regelmäßigen Abständen das Abbild refreshen.
recordset.refresh

So kann zum Beispiel folgender Fehler entstehen:
User1 möchte wissen wieviel DS vorhanden sind.
Er öffnet die DB mit dynaset (momentan 10 DS vorhanden)
User2 fügt 1 Sekunde später 1.000 Datensätze hinzu.
User1 will nun 2 Sekunden nach öffnen das Recordsets ausgegeben bekommen wieviele DS vorhanden sind.
Er bekommt von seinem dynaset (temp tabelle) ein Count von 10 Stück zurück....

Was ist passiert? Er hat vergessen das Dynaset zu refreshen.


Ich hoffe das hilft euch ein wenig diese blöden MaxLocks zu verhindern.
Eventuell stellt ihr die Datenbank auf ein niedrigeres Lock in den "Current DB" settings.
Ansonsten versucht euch mal mit Transaktionen oder ihr achtet im Code darauf das ihr die Datenbank nur solange geöffnet habt, wie ihr auch wirklich etwas auslest/schreibt.
Um ein FORM anzuzeigen mit dem Inhalt einer DB muss die DB nicht geöffnet sein.

Viel Erfolg.
Bitte warten ..
Ähnliche Inhalte
Sicherheit
Virenscanner gestern vs. heute
Tipp von FA-jkaSicherheit14 Kommentare

Hallo, Gestern: „Oh toll“! Heute: „Oh Mist“! Ich empfehle Format C: zynische Grüße, Jörg

Router & Routing
Ubiquiti EdgeRouter Pro (ERPRO-8) (vs. Cisco RV325)
Erfahrungsbericht von stephan902Router & Routing7 Kommentare

Heute hab ich von einem Cisco RV325 auf einen Ubiquiti EdgeRouter Pro gewechselt, die hierzulande zu ähnlichen Preisen gehandelt ...

Windows 10
Assigned access unter Win10 (1511) buggy bis unters Dach
Erfahrungsbericht von DerWoWussteWindows 101 Kommentar

Zur Info: Was unter Win8 noch funktionierte, ist mal wieder "überarbeitet" worden, schönen Dank dafür, Microsoft. Will man einem ...

Windows 10
Windows 10: Alle Einträge aus dem Schnellzugriff (Quick access) im Explorer mit Powershell entfernen
Tipp von colinardoWindows 103 Kommentare

Wer es gebrauchen kann, ein Powershell-Einzeiler zum Entfernen aller Einträge aus dem Schnellzugriff (quick access) im Windows-Explorer. Und schon ...

Neue Wissensbeiträge
Windows 10

Autsch: Microsoft bündelt Windows 10 mit unsicherer Passwort-Manager-App

Tipp von kgborn vor 10 MinutenWindows 10

Unter Microsofts Windows 10 haben Endbenutzer keine Kontrolle mehr, was Microsoft an Apps auf dem Betriebssystem installiert (die Windows ...

Sicherheits-Tools

Achtung: Sicherheitslücke im FortiClient VPN-Client

Tipp von kgborn vor 1 StundeSicherheits-Tools

Ich weiß nicht, wie häufig die NextGeneration Endpoint Protection-Lösung von Fortinet in deutschen Unternehmen eingesetzt wird. An dieser Stelle ...

Internet

USA: Die FCC schaff die Netzneutralität ab

Information von Frank vor 16 StundenInternet2 Kommentare

Jetzt beschädigt US-Präsident Donald Trump auch noch das Internet. Der neu eingesetzte FCC-Chef Ajit Pai ist bekannter Gegner einer ...

DSL, VDSL

ALL-BM200VDSL2V - Neues VDSL-Modem mit Vectoring von Allnet

Information von Lochkartenstanzer vor 19 StundenDSL, VDSL1 Kommentar

Moin, Falls jemand eine Alternative zu dem draytek sucht: Gruß lks

Heiß diskutierte Inhalte
Netzwerkmanagement
Mehrere Netzwerkadapter in einem PC zu einem Switch zusammenfügen
Frage von prodriveNetzwerkmanagement21 Kommentare

Hallo zusammen Vorweg, ich konnte schon einige IT-Probleme mit Hilfe dieses Forums lösen. Wirklich klasse hier! Doch für das ...

Hardware
Links klick bei Maus funktioniert nicht
gelöst Frage von Pablu23Hardware16 Kommentare

Hallo erstmal. Ich habe ein Problem mit meiner relativ alten maus jedoch denke ich nicht das es an der ...

Windows Server
Anmeldung direkt am DC nicht möglich
Frage von ThomasGrWindows Server16 Kommentare

Hallo, ich habe bei unserem Server 2016 Standard ein Problem. Keine Ahnung wie das auf einmal passiert ist. Ich ...

TK-Netze & Geräte
VPN-fähige IP-Telefone
Frage von the-buccaneerTK-Netze & Geräte14 Kommentare

Hi! Weiss noch jemand ein VPN-fähiges IP-Telefon mit dem man z.B. einen Heimarbeitsplatz gesichert anbinden könnte? Habe nur einen ...