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

Mitglied: J0j0

J0j0 (Level 1) - Jetzt verbinden

08.07.2009, aktualisiert 06.08.2010, 12022 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

Humor (lol)
Telekom vs. O2 - 3:2
Erfahrungsbericht von the-buccaneerHumor (lol)4 Kommentare

Unglaublich aber wahr: Nachdem mein privater Anschluss am 19.04.18 auf VOIP und VDSL umgestellt wurde, hatte ich seitdem 1,5 ...

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 ...

Neue Wissensbeiträge
SAN, NAS, DAS
QNAP NAS Datenschutz-Loop nach Firmware-Update
Tipp von vanTast vor 5 StundenSAN, NAS, DAS

Moin, im allgemeinen Trend seine geänderten Datenschutzbedingungen den Kunden zukommen zu lassen kam die Firma QNAP auf die glorreiche ...

Datenschutz
DSGVO Datenschutzgesetz
Anleitung von 1Werner1 vor 6 StundenDatenschutz4 Kommentare

Moin, ja was ist das, da ist die DSGVO Datenschutzverordnung. Wie das Gesetz gibt es schon 2 Jahre? Nun ...

CPU, RAM, Mainboards
Neverending story
Tipp von keine-ahnung vor 1 TagCPU, RAM, Mainboards1 Kommentar

Da kommt man mit dem fixen gar nicht mehr hinterher und die CPU erreichen wieder Rechenleistungen im Bereich des ...

Multimedia & Zubehör
AVM Fritz USB WLAN Sticks schneller einschalten
Tipp von NetzwerkDude vor 3 TagenMultimedia & Zubehör4 Kommentare

Die AVM Fritz WLAN Sticks haben in der Firmware 2 Modis: Einmal als Massenspeicher und einmal als WLAN Netzwerkkarte ...

Heiß diskutierte Inhalte
PHP
Nach Umzug zu 1und1 bekomme ich beim Eintrag in die DB Tabelle folgenden Fehler
gelöst Frage von jensgebkenPHP35 Kommentare

INSERT command denied to user 'dbo45342345342231244'@'112.127.102.073' for table 'orders'

LAN, WAN, Wireless
Powerline über zwei Stockwerke optimieren
Frage von DultusLAN, WAN, Wireless31 Kommentare

Guten Morgen liebes Forum, ich hätte einmal eine Frage bezüglich Powerline Adapter: Mein Problem ist seit gestern präsent, da ...

Windows Userverwaltung
Problem mit Benutzerprofil
Frage von lieferscheinWindows Userverwaltung24 Kommentare

Guten Tag liebe Community, folgendes Problem habe ich: User meldet sich auf Client A an - sein Homelaufwerk verbindet. ...

Rechtliche Fragen
DSGVO - Impressum und Datenschutz auf Anmeldeseiten notwendig?
Frage von StefanKittelRechtliche Fragen20 Kommentare

Hallo, was mit gerade eingefallen ist. Muss man auf Anmeldeseiten auch ein Impressum und Datenschutzhinweis haben? Auch hier wird ...