Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Datenbankstruktur zur Laufzeit verändern (https://www.delphipraxis.net/57157-datenbankstruktur-zur-laufzeit-veraendern.html)

Angel4585 16. Nov 2005 15:11

Datenbank: Paradox • Version: 7 • Zugriff über: TTable

Datenbankstruktur zur Laufzeit verändern
 
Hallo zusammen

Ich habe eine Datenbank mit sagen wir mal 10 Felder.

In jedem dieser Felder stehen Daten. ich möchte jetzt 2 Felder der Datenbank hinzufügen und ein altes entfernen. Jemand ne Ahnung wie ich das mache?

Ich habs mit
Delphi-Quellcode:
FieldDefs.Find('Feldname').Delete
Fields.Remove(FieldByName('Feldname').Index)
probiert.

Allerdings sind die Felder danach immernoch da. Hab ich was vergessen?

Ich würde ja mit CreateTable eine neue Tabelle erstellen und die Daten rüber kopieren.
Wenn ich das aber mache sind die Nummern von dem AutoIncFeld wieder ab 0 statt ab 10000. Also wenn mir jemand sagen könnte wie ich die Werte des AutoIncFelds eins zu eins kopieren könnte würde mir das auch schon reichen. Habs mit:

Delphi-Quellcode:
Table1.FieldDefs.Find('Nummer').DataType:=ftInteger;
Table1.Open;
Table2.Open;
Table1.BatchMove(Table2,batCopy);
table2.close;
table1.close;
table1.FieldDefs.Find('Nummer').DataType:=ftAutoInc;
probiert, allerdings werden trotzdem nicht die Werte übernommen sondern es fängt wieder bei 1 an.

Hoffe auf die Mainzelmännchen die heute Abend ein paar gute Ansätze springen lassen. :zwinker:

Ich muss dann los, meld mich Morgen wieder.

marabu 16. Nov 2005 15:43

Re: Datenbankstruktur zur Laufzeit verändern
 
Hallo Martin,

das machst du am einfachsten über LOCAL-SQL:

SQL-Code:
ALTER TABLE tabelle
  ADD COLUMN spalteA CHAR(20),
  ADD COLUMN spalteB INTEGER,
  DROP COLUMN spalteC
Wenn die Felder Teil eines Index sind, dann wird es etwas aufwendiger.

Grüße vom marabu

Angel4585 17. Nov 2005 07:10

Re: Datenbankstruktur zur Laufzeit verändern
 
SQL bei einer TTable? Wie geht das denn? :gruebel:

marabu 17. Nov 2005 07:12

Re: Datenbankstruktur zur Laufzeit verändern
 
Weißt du nicht, dass du in ein und dem selben Programm sowohl TTable- als auch TQuery-Komponenten einsetzen kannst - sogar mehrere davon?

Freundliche Grüße vom marabu

Angel4585 17. Nov 2005 07:22

Re: Datenbankstruktur zur Laufzeit verändern
 
doch klar.. muss ich eben auf Query umstellen

Sharky 17. Nov 2005 07:26

Re: Datenbankstruktur zur Laufzeit verändern
 
Zitat:

Zitat von marabu
.... sowohl TTable- als auch TQuery-Komponenten einsetzen kannst ...

Als Ergänzung zu marabus Beitrag möchte ich noch anmerken das Du dir überlegen solltest nicht ganz auf die TTable zu verzichten und ausschliesslich mit TQuerys zu arbeiten. Spätestenz wenn Du mal einge größere Tabelle in der DB hast und diese nicht local auf dem Rechner liegt bedeutet die Verwendung von TTable einen möglichen (großen) Geschwindigkeits verlust.

RavenIV 17. Nov 2005 07:27

Re: Datenbankstruktur zur Laufzeit verändern
 
Zitat:

Zitat von Angel4585
SQL bei einer TTable? Wie geht das denn? :gruebel:

und was steckt wohl hinter einer TTable?
vermutlich eine Tabelle in einer Datenbank!
und eine Tabelle einer Datenbank kann ich sehr wohl mit SQL direkt bearbeiten...

Man muss es ja nicht im Quellcode machen mit TQuery, sondern man kann es ja in einem Datenbank-Tool (DB-Explorer oder so was) machen.

ausserdem ist es eh eine schlechte Idee, TTable zu verwenden (ausser es handelt sich um BDE / Paradox).

Angel4585 17. Nov 2005 07:34

Re: Datenbankstruktur zur Laufzeit verändern
 
@Raven
:mrgreen: Es handelt sich um BDE/Paradox

RavenIV 17. Nov 2005 07:43

Re: Datenbankstruktur zur Laufzeit verändern
 
Zitat:

Zitat von Angel4585
@Raven
:mrgreen: Es handelt sich um BDE/Paradox

na und?
wir haben hier in der firma auch noch einige Datenbanken mit BED/Paradox.
und auch diese werden direkt mit SQL und TQuery bearbeitet.
ausserdem: seit wir fast alle TTables eliminiert haben, ist die Software wieder richtig schnell geworden...

Angel4585 17. Nov 2005 08:01

Re: Datenbankstruktur zur Laufzeit verändern
 
Hä? :gruebel: Ich habs grad irgendwie mit der TTable und den Befehlen von weiter oben zum Laufen gebracht.. keine Ahnung wie aber es geht auf einmal.

Also genauer:

Ich nimm die Struktur der eigentlichen Tabelle.
Entferne die Felder die ich nichtmehr brauche und füge die neuen hinzu und benenne welche einfach um mit :
Delphi-Quellcode:
   FieldDefs.Delete(FieldByName('Feld1').Index);
   Fields.Remove(FieldByName('Feld1'));

   FieldDefs.Find('Feld2').Name:='Feld3';
   FieldDefs.Add('FeldNeu',ftBoolean);
Dann benenne ich die Tabelle um in nen temporären Namen
und danach kopiere ich die Daten aus einer zweiten Tablekomponente in die erste Kompo, lösche danach die original Tabelle und benenne danach die temp Tabelle in die originalTabelle um.

Aber warum schrumpft die Tabelle jetzt so zusammen? von ursprünglich 90 MB auf grademal noch 30?


Alle Zeitangaben in WEZ +1. Es ist jetzt 08:51 Uhr.
Seite 1 von 2  1 2      

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