AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL -Befehl 'CreateTables' at runtime
Thema durchsuchen
Ansicht
Themen-Optionen

SQL -Befehl 'CreateTables' at runtime

Ein Thema von wendelin · begonnen am 22. Sep 2023 · letzter Beitrag vom 25. Sep 2023
Antwort Antwort
wendelin

Registriert seit: 29. Dez 2010
Ort: Nürnberg
126 Beiträge
 
Delphi 7 Enterprise
 
#1

SQL -Befehl 'CreateTables' at runtime

  Alt 22. Sep 2023, 23:24
Datenbank: Interbase • Version: 6.5 • Zugriff über: IB-Componenten
Hallo,
zunächst möchte ich Herrn Jaenicke für seine Antwort auf meine Frage zum Thema 'Create Tables' vom 11.09.23 danken.
Ich habe mein Problem vollständig gelöst, wenn auch mit Schwierigkeiten.
Nun habe ich aber ein neues Problem. Siehe Pfeil auf die Zeile s := 'CREATE TABLE Extend '
Ich möchte den TableName (hier z.B. Extend ) nicht statisch innerhalb des kompletten Strings schreiben ,sondern als z.B.als Übergabe von Edit.Text.
Dies geht aber nicht, denn wenn ich die procedure aufrufe wird mir zwar RunTime eine neue Tabelle erzeugt,allerdings dann mit dem Namen Extend.
Geht das überhaupt mit SQL und wenn ja wie ?



Delphi-Quellcode:
(*        Create Tables on RunTime           *)
(*       TEIL3 --- TEIL3 --- TEIL3           *)
(* ----------------------------------------- *)
procedure TForm3.BitBtn2Click(Sender: TObject);
(* ----------------------------------------- *)
VAR s , Extend : STRING;
begin
   Extend := Edit1.Text;
--> s := 'CREATE TABLE Extend '
       + '('
       + ' ID1 INTEGER NOT NULL PRIMARY KEY, '
       + ' Stock CHAR(35), '
       + ' AktDatum DATE, '
       + ' StockOPEN NUMERIC(15,2), '
       + ' StockHigh NUMERIC(15,2), '
       + ' StockLOW NUMERIC(15,2), '
       + ' StockCLOSE NUMERIC(15,2) '
       + ');';

  with Datamodule2 do
  begin
    If IBD.Connected = True Then IBD.Close;
    IBD.Params.Clear;
    IBD.Params.Values['user_name'] := 'SYSDBA';
    IBD.Params.Values['password'] := 'masterkey';
    IBD.DatabaseName := g_DBPfad;
    IBD.Open;
    //neue Transaktion starten
    if not IBT.InTransaction then IBT.StartTransaction;
    //SQL-String setzen
    IBSQL.SQL.Clear;
    IBSQL.SQL.Add(s);
    //SQL Anweisung ausführen
    IBSQL.ExecQuery;
    IBT.Commit;
    IBD.Connected := false;
  end;
end;

Danke , Wolfgang
Wolfgang
  Mit Zitat antworten Zitat
Benutzerbild von blawen
blawen

Registriert seit: 1. Dez 2003
Ort: Luterbach (CH)
677 Beiträge
 
Delphi 12 Athens
 
#2

AW: SQL -Befehl 'CreateTables' at runtime

  Alt 22. Sep 2023, 23:34
VAR s , Extend : STRING;
begin
Extend := Edit1.Text;
--> s := 'CREATE TABLE Extend '
Den Variablenname würde ich als erstes umbenennen, z.B. in sTabellenname.
Das ganze könnte z.B. so aussehen.
Delphi-Quellcode:
var s, sTabellenname : String;

begin
  sTabellenname := Edit1.Text;
  s := 'CREATE TABLE ' + sTabellname
     + '('
     +....
Sofern der Inhalt von Edit1 nicht überprüft wird, kann auf die Variable sTabellename verzichtet werden.
Sprechende Namen sind immer hilfreich:
Edit1.Text -> edTabellenname

Dies könnte dann z.B. so aussehen:
Delphi-Quellcode:
var
  sSQL : String;

begin
  sQL := 'CREATE TABLE ' + edTabellenname.Text
       + '('
       +....
Gruss
Roland

Geändert von blawen (22. Sep 2023 um 23:47 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.387 Beiträge
 
Delphi 12 Athens
 
#3

AW: SQL -Befehl 'CreateTables' at runtime

  Alt 23. Sep 2023, 09:10
Zitat:
Sprechende Namen sind immer hilfreich
+1 ...dann braucht man auch keine ungarische Notation...die imho heutzutage verpönt ist. PS: Die Präfixe der Komponenten (edtXXX) zählen nicht dazu...
https://de.wikipedia.org/wiki/Ungarische_Notation

Delphi-Quellcode:
with Datamodule2 do
begin

Warum wird das immer noch benutzt, obwohl alle davor warnen!

Geändert von haentschman (23. Sep 2023 um 11:02 Uhr)
  Mit Zitat antworten Zitat
wendelin

Registriert seit: 29. Dez 2010
Ort: Nürnberg
126 Beiträge
 
Delphi 7 Enterprise
 
#4

AW: SQL -Befehl 'CreateTables' at runtime

  Alt 23. Sep 2023, 11:32
Hallo Roland,

vielen Dank für Deine Anrwort.
Es hat auf Anhieb geklappt. Super ! Ich denke, ich muß noch Einiges lernen.. aber ich bin ja erst 78!
Ich habe jetzt noch 2 Fragen.
1. kann ich mit dem selben Schema SQL -> 'DROP TABLE' programmieren ?
2. Bei einem Einplatzsystem (Interbase) : gibt es prnzipiell einen Unterschied zwischen 'DROP DATABASE' und dem einfachen Löschen
des Datenbank-Files ?

Gruß
Wolfgang
Wolfgang
  Mit Zitat antworten Zitat
Benutzerbild von blawen
blawen

Registriert seit: 1. Dez 2003
Ort: Luterbach (CH)
677 Beiträge
 
Delphi 12 Athens
 
#5

AW: SQL -Befehl 'CreateTables' at runtime

  Alt 25. Sep 2023, 13:04
Hallo Roland,

vielen Dank für Deine Anrwort.
Es hat auf Anhieb geklappt. Super ! Ich denke, ich muß noch Einiges lernen.. aber ich bin ja erst 78!
Ich habe jetzt noch 2 Fragen.
1. kann ich mit dem selben Schema SQL -> 'DROP TABLE' programmieren ?
2. Bei einem Einplatzsystem (Interbase) : gibt es prnzipiell einen Unterschied zwischen 'DROP DATABASE' und dem einfachen Löschen
des Datenbank-Files ?

Gruß
Wolfgang
Hallo Wolfgang

1) Ja, dies geht. Beim Text in den Hochkommatas handelt es sich um einen String und mit dem
Zitat:
+ edTabellenname.Text
kann man den variablen Text anhängen. Zu beachten ist, dass vor dem letzten Hochkomma noch ein Leerzeichen steht.

2) Interbase kenne ich nicht speziell, aber es dürfte bei allen Systemen ähnlich sein.
Theoretisch ist es das gleiche, aber das manuelle Löschen der Files ist eine schlechte Option.
Zum einen kann es sein, dass die Datenbank die Files noch sperrt und zum anderen werden interne Einträge (z.B. in der Registry) nicht sauber entfernt.

Darum immer Drop Database verwenden.

Gruss
Roland
Roland
  Mit Zitat antworten Zitat
wendelin

Registriert seit: 29. Dez 2010
Ort: Nürnberg
126 Beiträge
 
Delphi 7 Enterprise
 
#6

AW: SQL -Befehl 'CreateTables' at runtime

  Alt 25. Sep 2023, 17:48
Hallo Roland,

vielen Dank für Deine kenntnissreichen Antworten.
Mit dem Befehl 'DROP TABLE' klappt es auch.
Wenn ich mal zu Datenbanken (Interbase) noch Fragen habe, werde ich mich
vertrauensvoll an Dich wenden !?
Ich hoffe, es ist Dir recht.

Gruß
Wolfgang
Wolfgang
  Mit Zitat antworten Zitat
Antwort Antwort


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 00:18 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