Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

Komprimieren einer kennwortgeschützten Access-Datenbank

Frage Entwicklung Visual Studio

Mitglied: lobo0108

lobo0108 (Level 1) - Jetzt verbinden

13.11.2012 um 22:33 Uhr, 4577 Aufrufe, 4 Kommentare

Hallo Access-/VBS-Freaks,

Ich suche eine Lösung für ein (für mich) fast unlösbares Problem unter Access 2002. In einer Access-Datenbank wurde ein Datenbank-Kennwort definiert. Es handelt sich hierbei um einen Verwaltungsclient für den Austausch mit dem externen WebServer, welcher eine Datenbank vorhält, welche sich nachts mit dem Artikelstamm unseres ERP-Systems synchronisiert. Aufgrund der Synchronisierung bläht sich das Volumen der Access-Datenbank nach 3-4 Tagen derart auf, dass die automatisierte Übertragung der Daten auf den Webserver nicht mehr möglich ist. Die Datenbank ist mit einem Kennwort versehen.

Ich suche eine Möglichkeit, wie ich die Datenbank über VBS nach 2-3 Tagen automatisiert über Batch bzw. VB-Script auf ein erträgliches Niveau reduzieren kann. Bisher ging das nur manuell. Wir wollen folgenden Source verwenden:

Dim DBProvider, DBName, DBPwd

DBProvider = "Microsoft.Jet.OLEDB.4.0" ' Access 2000
DBName="D:\temp\eidamo1.mdb" ' Datenbankname
DBPwd="test" ' Datenbankpasswort

Call DBKomprimieren (DBProvider,DBName)

Public Sub DBKomprimieren(DBProvider,DBName)
Dim JRO, FSO

Set FSO = CreateObject("Scripting.FileSystemObject")

Set JRO = CreateObject("JRO.JetEngine")
Dim tDBName
tDBName = "t" & DBName
If FSO.FileExists(tDBName)=TRUE Then FSO.DeleteFile(tDBName)

Call JRO.CompactDatabase( _
"Provider=" & DBProvider & ";Jet OLEDB:Database Password=" & DBPwd & ";Data Source=" & DBName, _
"Provider=" & DBProvider & ";Jet OLEDB:Database Password=" & DBPwd & ";Data Source=" & tDBName _
& ";Jet OLEDB:Engine Type=5")

Set JRO = Nothing

FSO.DeleteFile(DBName)

Call FSO.MoveFile(tDBName,DBName)

End Sub


Das funktioniert jedoch nicht - wer kann mir helfen??


Gruß

Markus
Mitglied: Xaero1982
13.11.2012, aktualisiert um 23:39 Uhr
Nabend,

benutze bitte die code Tags

Ansonsten sollte das auch eine einfache Batch hinbekommen...
http://office.microsoft.com/de-de/access-help/befehlszeilenswitches-fur ...

"Funktioniert nicht" ist leider auch keine Fehlerbeschreibung ...

Gruß
Bitte warten ..
Mitglied: lobo0108
14.11.2012 um 02:24 Uhr
Hallo Xaero1982,

bevor ich das mit dem beigefügten Script versuchen wollte, habe ich das mit diversen cmd-Befehlen bereits hinter mir. Der von Dir verwendete Link verweisst auf eine Access2007-Datenbank. Funktioniert jedoch auch unter Bezug auf eine mdb nicht, weil der Parameter \pwd nur in Kombination mit \user funkioniert, und sich darüber hinaus auf die User-Rechte und nicht auf ein DBKennwort bezieht. Ich habe in dieser Kombination bisher keine Möglichkeit gefunden, eine kennwortgeschützte DB über cmd zu öffnen. Die \pwd- Syntax funktioniert nicht. Als einzigster User ist in dieser Datenbank Administrator angelegt. Der Aufruf mit \user Administrator \pwd test geht ins Leere, weil es sich um ein DB-Kennwort handelt. Das funktioniert auch über den Batch-Aufruf über Access2007 genauso wenig!

Der einzigste mir bekannte Lösungsansatz verweist auf eines Aufruf über VB oder VBS. Einzig an der Ausführung scheitert es! Noch ein Hinweis: Ich führe das auf einem Win7-32 - Testsystem aus, während das Echtsystem unter WinXP-32 läuft.

Gruß

Markus
Bitte warten ..
Mitglied: Xaero1982
14.11.2012 um 11:32 Uhr
Hi Markus,

ok das ist natürlich ungünstig. Ich habe nur leider keine Access 2002 DB mit der ich irgendwas testen könnte.

Und deine Fehlerbeschreibung zum VBscript... was genau geht denn nicht? Fehlermeldung? Öffnet er es nicht? etc.

Gruß
Bitte warten ..
Mitglied: lobo0108
14.11.2012 um 13:51 Uhr
Hi Xaero1982,

das kannst Du mit jeder Access-Version nachstellen. Weise einfach über Extras/Sicherheit einer Datenbank ein Kennwort zu (die Datenbank muss zuvor excl. geöffnet werden). Mir war es nicht möglich über ein Script diese Datenbank mit Übergabe dieses Passworts wieder zu öffnen. Ich kann das Datenbank-Kennwort nicht einfach löschen, weil die WebShop-Verwaltung darauf zugreift und wahrscheinlich dieses Passwort prüft.

Für mich wäre es durchaus vorstellbar über Script das Datenbankkennwort zu löschen, dann die Datenbank komprieren und anschliesend das Datenbankkennwort wieder neu zu setzen; das stellt für mich jedoch keine optimale Lösung dar.

Und das VBS-Script funktioniert gar nicht - es geht kein Fenster auf, keine Fehlermeldung erscheint und die Datenbank ist noch genauso groß wie vorher.

Gruss
Bitte warten ..
Ähnliche Inhalte
Datenbanken
gelöst MS Access Datenbank (18)

Frage von endada zum Thema Datenbanken ...

Batch & Shell
Scriptdatei komprimieren (12)

Frage von BigSanch zum Thema Batch & Shell ...

Windows 10
Kennwortgeschütztes Freigeben ausschalten nicht möglich

Frage von decker zum Thema Windows 10 ...

Datenbanken
Automatisierter täglicher Import einer Access Datenbank in SQL (5)

Frage von RichterS zum Thema Datenbanken ...

Neue Wissensbeiträge
Linux Netzwerk

Ping und das einstellbare Bytepattern

Erfahrungsbericht von LordGurke zum Thema Linux Netzwerk ...

Windows Update

Microsoft Update KB4034664 verursacht Probleme mit Multimonitor-Systemen

(3)

Tipp von beidermachtvongreyscull zum Thema Windows Update ...

Viren und Trojaner

CNC-Fräsen von MECANUMERIC werden (ggf.) mit Viren, Trojanern, Würmern ausgeliefert

(4)

Erfahrungsbericht von anteNope zum Thema Viren und Trojaner ...

Heiß diskutierte Inhalte
SAN, NAS, DAS
MSA 2050 RAID Konfig (24)

Frage von Leo-le zum Thema SAN, NAS, DAS ...

Netzwerkmanagement
Windows Server 2008 R2: "netsh reset" nicht verfügbar? (10)

Frage von RickTucker zum Thema Netzwerkmanagement ...

Netzwerkmanagement
Suche eine Software für Cloudverwaltung (6)

Frage von tsunami zum Thema Netzwerkmanagement ...

Google Android
Musik Wiedergabe am PC mit Smartphone über Bluetooth steuern (5)

Frage von justlukas zum Thema Google Android ...