AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Tabelle überschreiben
Thema durchsuchen
Ansicht
Themen-Optionen

Tabelle überschreiben

Ein Thema von ksh · begonnen am 22. Mai 2006 · letzter Beitrag vom 23. Mai 2006
Antwort Antwort
Seite 1 von 2  1 2      
ksh
(Gast)

n/a Beiträge
 
#1

Tabelle überschreiben

  Alt 22. Mai 2006, 13:41
Datenbank: Access • Version: 2003 • Zugriff über: ADO
Ich mal wieder!

Lasse eine Tabelle per ADO erzeugen. Nun ist es aber so, dass wenn die Tabelle schon vorhanden ist, eine Exception ausgeworfen wird. Gibt es einen Befehl, der es möglich macht, die Tabelle zu überschreiben?

Mein bisheriger Code:
Delphi-Quellcode:
// DDL-Statement in Property SQL schreiben
        ADOQuery1.SQL.Text := cCreateTabelle;
        // DDL-Statement ausführen
        ADOQuery1.ExecSQL;
        // DML-Statement zur Anzeige der Tabellendaten in die Property SQL schreiben
        ADOQuery1.SQL.Text := 'SELECT * FROM '+TName;
        // DML-Statement ausführen
        ADOQuery1.Open;
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Tabelle überschreiben

  Alt 22. Mai 2006, 13:44
Hi.

Ein DROP TABLE könnte dir helfen.

Grüße vom marabu
  Mit Zitat antworten Zitat
ksh
(Gast)

n/a Beiträge
 
#3

Re: Tabelle überschreiben

  Alt 22. Mai 2006, 14:02
hab das jetzt mal so ausprobiert:

Delphi-Quellcode:
        ADOQuery1.SQL.Text := 'DROP TABLE '+ TName;
        // DDL-Statement in Property SQL schreiben
        ADOQuery1.SQL.Text := cCreateTabelle;
        // DDL-Statement ausführen
        ADOQuery1.ExecSQL;
        // DML-Statement zur Anzeige der Tabellendaten in die Property SQL schreiben
        ADOQuery1.SQL.Text := 'SELECT * FROM '+TName;
        // DML-Statement ausführen
        ADOQuery1.Open;

die Logik stimmt ja - zuerst das ev. bereits vorhandene löschen (mit gleichem Namen), dann neues erzeugen. Er wirft aber immer noch die Exception aus...
  Mit Zitat antworten Zitat
Benutzerbild von mikhal
mikhal

Registriert seit: 11. Sep 2003
Ort: Linz am Rhein
796 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: Tabelle überschreiben

  Alt 22. Mai 2006, 14:09
Da fehlt ein ExecSQL nach dem "Drop Table"

Grüße
Mikhal
Michael Kraemer
Computer erleichtern die Arbeit...
...und die Erde ist eine Scheibe!
  Mit Zitat antworten Zitat
ksh
(Gast)

n/a Beiträge
 
#5

Re: Tabelle überschreiben

  Alt 22. Mai 2006, 14:24
Danke! Klappt mal wieder alles perfekt durch euch!
  Mit Zitat antworten Zitat
McLane

Registriert seit: 4. Sep 2004
37 Beiträge
 
Delphi 5 Professional
 
#6

Re: Tabelle überschreiben

  Alt 22. Mai 2006, 16:40
du musst aber aufpassen: Sollte die Tabelle noch nicht existieren gibt dir das erste Löschen eine Exception.
Schachtel das ganze ein:
Delphi-Quellcode:
        try
          DOQuery1.SQL.Text := 'DROP TABLE '+ TName;
          DOQuery1.ExecSQL;
        except
          // sollte die Tabelle nicht existieren die Exception abfangen.
        end;
          // DDL-Statement in Property SQL schreiben
        ADOQuery1.SQL.Text := cCreateTabelle;
        // DDL-Statement ausführen
        ADOQuery1.ExecSQL;
        // DML-Statement zur Anzeige der Tabellendaten in die Property SQL schreiben
        ADOQuery1.SQL.Text := 'SELECT * FROM '+TName;
        // DML-Statement ausführen
        ADOQuery1.Open;
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#7

Re: Tabelle überschreiben

  Alt 22. Mai 2006, 17:00
Hallo Leute,

noch besser: vor dem Löschen prüfen, ob die Tabelle existiert:

Delphi-Quellcode:
function TableExists(conn: TAdoConnection; tableName: String): Boolean;
var
  s: TStrings;
begin
  s := TStringList.Create;
  conn.GetTableNames(s);
  Result := s.IndexOf(tableName) >= 0;
  s.Free;
end;
Grüße vom marabu
  Mit Zitat antworten Zitat
ksh
(Gast)

n/a Beiträge
 
#8

Re: Tabelle überschreiben

  Alt 22. Mai 2006, 21:36
hey! bin gerade am ausprobieren.

aber leider mache ich was bei der Funktion falsch. Er gibt immer an, dass er die Parameter nicht identifizieren kann - also die Connection und den String.

kann ich denn auch eine solch ähnliche Funktion für eine Spalte der Tabelle schreiben?
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#9

Re: Tabelle überschreiben

  Alt 23. Mai 2006, 07:27
Guten Morgen.

Welche Delphi Version verwendest du? Lässt sich der Code bei dir nicht übersetzen oder erhältst du einen Laufzeitfehler?

Delphi-Quellcode:
function FieldExists(conn: TADOConnection; const tableName, fieldName: String): Boolean;
var
  s: TStrings;
begin
  s := TStringList.Create;
  conn.GetFieldNames(tableName, s);
  Result := s.IndexOf(fieldName) >= 0;
  s.Free;
end;
Grüße vom marabu
  Mit Zitat antworten Zitat
ksh
(Gast)

n/a Beiträge
 
#10

Re: Tabelle überschreiben

  Alt 23. Mai 2006, 08:29
Ich verwende Delphi 7 professional.

Der Code lässt sich nicht übersetzen und es wir als Fehler ausgegeben:
Undefinierter Bezeichner: TADOConnection
  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 06:45 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