Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Kleine Datenbank ?? (https://www.delphipraxis.net/47095-kleine-datenbank.html)

Gigant02 6. Jun 2005 17:33

Datenbank: ???? • Zugriff über: ????

Kleine Datenbank ??
 
Hallo ich wollte ein Adressbuch programmieren und frage mich nun wie ich die daten an besten speicher


also ich will das programm auch weiter geben also kein paradox
einen server zuinstallieren finde ich auch blöd also kein mysql

was könnte ich noch nehmen ???

lg, Gigant02

wfoertsch 6. Jun 2005 17:36

Re: Kleine Datenbank ??
 
Hallo,

kannst dir ja mal Absolute Database anschauen das ist eine Filebasierte Datenbank ...
Du kannst damit z.b die DB in die EXE einbinden.

Gruss Wolfgang

Hansi 6. Jun 2005 17:36

Re: Kleine Datenbank ??
 
Vielleicht ist die Access Datenbank das richtige für Dich!

Gigant02 6. Jun 2005 17:46

Re: Kleine Datenbank ??
 
@wfoertsch klingt nett :) schaue ich mir mal an


nee access will ich nicht, kenn ich mich auch nicht so mit aus

lg, Ciam

Hansi 6. Jun 2005 17:51

Re: Kleine Datenbank ??
 
Vielleicht kannst Du es ja auch mit einer Textdatei versuchen! Sollte für Deine Anwendung doch ausreichen?

Phoenix 6. Jun 2005 18:05

Re: Kleine Datenbank ??
 
Eine Lösung: Firebird Embedded .
Du musst hier nur eine .dll (oder ein paar?) mit ausliefern, die Datenbank (eine komplette Firebird) wird innerhalb Deiner .exe -Datei gestartet und steht mit allen Features als normale SQL-Datenbank zur Verfügung.

Alternative: Du speicherst Deine Daten in XML-Form. Dazu gibt es meines Wissens nach sogar einen Treiber, den man irgendwie so verwenden kann als sei das dann eine Datenbank.

2. Alternative: Jet. Du verwendest die Microsoft Data Access Components (MDAC) und sprichst darüber die Jet - Datenbankengine an. Du hast dann Datenbankfiles mit denen Du wie mit einer Datenbank arbeiten kannst. Ist auch relativ einfach und lässt sich mit Delphi-Hausmitteln auch supereinfach ansprechen.

Gigant02 6. Jun 2005 18:30

Re: Kleine Datenbank ??
 
@Phoenix
hast du dafür eine anleitung ??
also der access geschichte ??


und wie ist denn das Absolute Database system ??

lg, Gigant

mason 6. Jun 2005 22:24

Re: Kleine Datenbank ??
 
Oder auch die TDBF (ist bei Sourceforge zu finden) beachten.

PierreB 6. Jun 2005 22:29

Re: Kleine Datenbank ??
 
Zitat:

Zitat von Hansi
Vielleicht kannst Du es ja auch mit einer Textdatei versuchen! Sollte für Deine Anwendung doch ausreichen?

Hm, kommt immer drauf an wieviele Einträge das Adressbuch denn haben soll. Doch egal wieviel, statt Textdateien würde ich eher Ini-Dateien empfehlen. (in der DP-Suche sollte man alles dazu finden oder die Tutorials auf http://dsdt.info)

Ich würde sagen wenn du die Datenbank direkt in die EXE einbindest (wie oben gesagt) dürfte dein Programm zieeeeemlich groß werden. ;)

alcaeus 6. Jun 2005 22:38

Re: Kleine Datenbank ??
 
Hallo allerseits,

fuer eine "kleine Anwendung" wie eben ein Adressbuch, ist eine Datenbankloesung in einigen Faellen zu viel des Guten *g*
Dafuer gibt es einige einfachere Loesungen:
  • Typed files/records:
    Man erstellt sich einen Record, der alle Daten beinhalten kann:
    Delphi-Quellcode:
    type
      TAddressRec = record
        LastName, FirstName, Address: String[255];
      end;
    Sowie einen Typ fuer die Datei vom Typ der Records:
    Delphi-Quellcode:
    TAddressFile = file of TAddressRec
    Arbeiten kann man anschliessend mit [oh]AssignFile, Reset, Rewrite, Append, Write, Read, CloseFile[/oh]. Nachteile: die Dateien sind zu anderen Versionen derselben Datei (also wenn sich die Recordstruktur aendert) so gut wie gar nicht kompatibel, und der Datentyp muss finalisiert sein, also eine fixe Laenge haben. Deshalb kann man z.B. keinen "normalen" String mit einer variablen Laenge von bis zu 2 GB verwenden, sondern muss auf ShortString zurueckgreifen :wall:
  • XML-Dateien:
    Guck dir dazu am besten [user=Chakotay1308]Chris'[/user] XML-Tutorial an. Diese Loesung ist viel dynamischer als typed files.
  • Collections:
    Meine Lieblingsgruppe. Guck dir dazu den Thread in der Codelib an. Ich arbeite zur Zeit noch an einem Tutorial zu den Collections, habe im Moment aber wenig Zeit, es fertigzustellen. Bei Interesse kann ich dir aber eine kleine Vorab-Version zukommen lassen.

Von der Verwendung von ini-Dateien zur Datenspeicherung rate ich ab, da sie einfach nicht dafuer geschaffen wurden. Bei 32 KB (oder warens 64 KB? :gruebel:) ist Schluss.

Ich hoffe das hilft dir ein bisschen bei deiner Auswahl.

Greetz
alcaeus

alzaimar 7. Jun 2005 06:48

Re: Kleine Datenbank ??
 
IMHO sollte man, wenn irgend möglich, einen TDataset-Abklömmling benutzen, weil man dann (jedenfalls bei diesen einfachen Aufgaben) am wenigsten um die Ohren hat und eigentlich nichts mehr selbst programmieren muss. Es muss ja nicht gleich eine Datenbank sein, Access reicht doch aus. Oder DBF. Oder eben eine Textdatei.

Gibt es irgendwo ein TDataset, das mit Textdateien arbeitet und keinerlei ADO, BDE o.ä. benötigt?

Gigant02 7. Jun 2005 17:32

Re: Kleine Datenbank ??
 
OK gut xml klingt ja auch nett

aber was ist das genau alls schreien xml und hier und da aber was ist das genau ??

würde das ohne grofen aufwand reichen um bei jeden rechner adressen zuspeichern ???

hmm txt datei habe ich mir auch schon gedacht problem ist nur wenn ich das programm weiterentwickle ist das sehr umständlich aber es kann für mich nicht schaden mal das thema text datein durchzunehemen


lg, Gigant

alcaeus 7. Jun 2005 17:35

Re: Kleine Datenbank ??
 
Hallo Gigant02,

Zitat:

Zitat von Gigant02
aber was ist das genau alls schreien xml und hier und da aber was ist das genau ??

XML ist eine Deklarationssprache, die z.B. auch als Basis fuer HTML dient. Guck dir einfach das oben verlinkte Tutorial an, und du wirst erkennen worums geht ;)

Greetz
alcaeus

Gigant02 7. Jun 2005 17:46

Re: Kleine Datenbank ??
 
jup bin ich bei kann es aber nicht anschauen es kommt immer die seite kann nicht geöffnet werden


hmm nun suche ich weiter scheint aber sehr interrassannt zusein

lg, gigant


Alle Zeitangaben in WEZ +1. Es ist jetzt 22:09 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