AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Access .mdb erstellen.
Thema durchsuchen
Ansicht
Themen-Optionen

Access .mdb erstellen.

Ein Thema von mika · begonnen am 16. Apr 2008 · letzter Beitrag vom 16. Apr 2008
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von mika
mika

Registriert seit: 25. Okt 2002
176 Beiträge
 
Delphi 6 Professional
 
#1

Access .mdb erstellen.

  Alt 16. Apr 2008, 13:59
Datenbank: MS Access • Version: 2003 • Zugriff über: ODBC Jet 4.0
Hallo an alle,

ich arbeite zur Zeit an einem Programm das aus einer Datei eine Datenbank anlegt. Keine Daten sondern nur die Struktur.
Mein Programm läd sich diese Datei mit SQL anweisungen von meinem Server und arbeitet die danach ab. Tabellen anlegen,
bearbeiten und so weiter funktioniert schon ganz gut, aber die eigentliche .mdb Datei (Programm unterstützt vorerst nur
MS Access über ODBC) anlegen funktioniert nicht.

Ich habe hier einen Tipp gefunden: http://entwickler-forum.de/archive/i...p/t-17577.html

Und dachte das ist genau das was ich brauche. Allerdings kann ich mein Projekt jetzt kompilieren, beim Aufruf von
AdoCatalog.Create(""); kommt allerdings zur Laufzeit die Fehlermeldung "Klasse nicht registriert". Hab schon gegoogelt
und die DP durchsucht aber nichts konkretes gefunden das mir hilft. Ich habe das Programm auch mal auf einem anderen
Rechner (WinXP, MDAC 2.8 SP1) getestet, aber bin zum gleichen Fehler gekommen.

Was genau muss ich denn machen damit Windows diese Klasse kennt und vor allem welche Sachen muss ich nachher mitliefern
damit mein Programm beim Client läuft?

Wäre für jede Hilfe dankbar suche schon seit fast 2 Tagen ohen Erfolg.
:: don't Panic ::
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Access .mdb erstellen.

  Alt 16. Apr 2008, 14:07
ist die Access-Runtime installiert?
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von TeronG
TeronG

Registriert seit: 19. Jul 2004
Ort: München
960 Beiträge
 
Delphi 2007 Professional
 
#3

Re: Access .mdb erstellen.

  Alt 16. Apr 2008, 14:09
Hi
gug doch mal hier rinn: http://www.mike-kraemer.de/html/adox.html

Evtl hilft dir das weiter.
Hab allerdings den Beitrag aus dem Entwicklerforum nicht gelesen ...
龍 Der Unterschied zwischen Theorie und Praxis ist in der Praxis größer als in der Theorie.
  Mit Zitat antworten Zitat
Benutzerbild von mika
mika

Registriert seit: 25. Okt 2002
176 Beiträge
 
Delphi 6 Professional
 
#4

Re: Access .mdb erstellen.

  Alt 16. Apr 2008, 14:58
die access runtime ist auf meiner entwicklermaschine nicht installiert aber access 2003 selber ist installiert, und das wird wahrscheinlich auch die runtime beinhalten oder?

wo kann ich das denn downloaden (brauch ich ja nachher für die clients) oder ist das MDAC_TYP.exe von MS?


Den Link kenn ich schon, das ist ja genau das was ich machen will was aber nicht funktioniert...
:: don't Panic ::
  Mit Zitat antworten Zitat
Relicted

Registriert seit: 24. Jan 2006
Ort: Iserlohn
646 Beiträge
 
Delphi 10.4 Sydney
 
#5

Re: Access .mdb erstellen.

  Alt 16. Apr 2008, 15:17
wie wärs denn wenn du eine leere mdb datei erstellst, diese dann als ressource an dein programm heftest und einfach nur aus der res speicherst und dann die tabellen und co anlegst? du lieferst also quasi ein "template" mit aus.

gruß
reli
  Mit Zitat antworten Zitat
Benutzerbild von mika
mika

Registriert seit: 25. Okt 2002
176 Beiträge
 
Delphi 6 Professional
 
#6

Re: Access .mdb erstellen.

  Alt 16. Apr 2008, 15:23
hab ich auch schon dran gedacht... aber ich dachte der weg wäre der "richtigere". scheint ja auch nicht allzu schwer zu sein laut den dokus die ich so gefunden habe bloss das ich diesen "klasse nicht registriert" fehler bekomme.

Kannst du mir einen guten Link zu den Dateien als Ressource anheften und speichern geben? Kann man garantiert nochmal gebrauchen
:: don't Panic ::
  Mit Zitat antworten Zitat
Relicted

Registriert seit: 24. Jan 2006
Ort: Iserlohn
646 Beiträge
 
Delphi 10.4 Sydney
 
#7

Re: Access .mdb erstellen.

  Alt 16. Apr 2008, 15:33
dann muss aber wahrscheinlich auf jedem client die RTL installiert sein. und das bläht nur ohne ende auf.
da du ja scheinbar dynamisch auf die mdb zugreifst solltest vielleicht den umweg über ODBC sein lassen?

hier so würdeste auf dateiebene drauf zugreifen:
Delphi-Quellcode:
const
// DB_PROVIDER = 'Microsoft.Jet.OLEDB.3.51'; // Access 97
   DB_PROVIDER = 'Microsoft.Jet.OLEDB.4.0'; // Access 2000
function MDBGetConnectionString(const MDBFile: string): string;
begin
   Result := Format('Provider=%s;Data Source=%s',[DB_PROVIDER,MDBFile]);
end;

//....

if OpenDialog1.Execute then
begin
  ADOConnection1.Connected := false;
  ADOConnection1.ConnectionString := MDBGetConnectionString( OpenDialog1.FileName );
  ADOConnection1.Connected := true;
end;
//...

hier zum datei aus res schreiben-fürs erstellen der res muss ich auch jedes mal die sufu benutzen. hab ich grad ned im kopf wie das geht.
http://www.delphipraxis.net/internal...t.php?t=121365
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#8

Re: Access .mdb erstellen.

  Alt 16. Apr 2008, 15:37
Hallo,

da das benötigte Com-Objekt in MSADOX.DLL steht,
würde ich einfach mal zum Registrieren

regsvr32 MSADOX.DLL

machen


Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von mika
mika

Registriert seit: 25. Okt 2002
176 Beiträge
 
Delphi 6 Professional
 
#9

Re: Access .mdb erstellen.

  Alt 16. Apr 2008, 15:50
hab die datei unter C:\Programme\Gemeinsame Dateien\System\ado\msadox.dll gefunden, regsvr32 hat auch funktioniert
aber ich bekomme immer noch die Fehlermeldung "Klasse nicht registriert" beim aufruf der zeile

Code:
Catalog1.Create('Provider=Microsoft.Jet.OLEDB. 4.0;Data Source=c:\new.mdb');
:: don't Panic ::
  Mit Zitat antworten Zitat
Ydobon

Registriert seit: 3. Mär 2006
264 Beiträge
 
Delphi 11 Alexandria
 
#10

Re: Access .mdb erstellen.

  Alt 16. Apr 2008, 17:39
Schau doch einmal nach, ob sie registriert ist, "HKEY_CLASSES_ROOT\ADOX.Catalog" müsste vorhanden sein.

Ist das Leerzeichen vor der 4 nur hier im Forum oder auch in deinem Quelltext?
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:27 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz