AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi TTable: Breite einer vorhandene Spalte nachträglich ändern
Thema durchsuchen
Ansicht
Themen-Optionen

TTable: Breite einer vorhandene Spalte nachträglich ändern

Ein Thema von Helmi · begonnen am 8. Jan 2009 · letzter Beitrag vom 9. Jan 2009
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.323 Beiträge
 
Delphi XE2 Professional
 
#1

TTable: Breite einer vorhandene Spalte nachträglich ändern

  Alt 8. Jan 2009, 22:27
Datenbank: Paradox • Zugriff über: TTable, BDE
Hallo,

wie kann ich naträglich, bei einer schon vorhandenen Tabelle, die Spaltenbreite ändern?
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: TTable: Breite einer vorhandene Spalte nachträglich ände

  Alt 8. Jan 2009, 22:35
Bin mir nicht ganz sicher, ob das in LocalSQL geht:

ALTER TABLE <Tabelle> ALTER <Spalte> <TYP>[( <Laenge>)];
Markus Kinzler
  Mit Zitat antworten Zitat
hoika

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

Re: TTable: Breite einer vorhandene Spalte nachträglich ände

  Alt 8. Jan 2009, 23:27
Hallo,

nö, so geht das nicht, aber so ...

http://info.borland.com/devsupport/b...structure.html
Example 4 kommt dem am nächsten.

DbiDoRestructure macht auch das.

Aber so nebenbei, es wird nicht die Breite einer Spalte,
sondern die Feldlänge eines Feldes einer Tabelle geändert.


Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

Re: TTable: Breite einer vorhandene Spalte nachträglich ände

  Alt 9. Jan 2009, 01:41
Zitat von hoika:
http://info.borland.com/devsupport/bde/bdeapiex/dbidorestructure.html
Example 4 kommt dem am nächsten.
Das ist zu lesen wie Memo.Lines.Count, also immer schön -1 also Example 3
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.323 Beiträge
 
Delphi XE2 Professional
 
#5

Re: TTable: Breite einer vorhandene Spalte nachträglich ände

  Alt 9. Jan 2009, 14:08
Gibts da auch was von SQL?
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
hoika

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

Re: TTable: Breite einer vorhandene Spalte nachträglich ände

  Alt 9. Jan 2009, 15:24
Hallo,

unter Paradox nicht.
Einzige Möglichkeit ist das Anlegen eines Feldes Feld2,
Daten dorthin kopieren, Feld1 löschen, Feld1 mit der neuen Länge erzuegen,
Daten aus Feld2 nach Feld1, Feld2 löschen.


Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.323 Beiträge
 
Delphi XE2 Professional
 
#7

Re: TTable: Breite einer vorhandene Spalte nachträglich ände

  Alt 9. Jan 2009, 15:26
ach so - na gut - dann muss ich das anders lösen

Trotzdem danke
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#8

Re: TTable: Breite einer vorhandene Spalte nachträglich ände

  Alt 9. Jan 2009, 15:37
Hallo,

per SQL sollte es so gehen:
SQL-Code:
alter table "xxxx.db" add column TempFeld DatentypVonUrsprungsfeld;
update "xxxx.db" set TempFeld = Ursprungsfeld;
alter table "xxxx.db" drop column Ursprungsfeld;
alter table "xxxx.db" add column Ursprungsfeld NeuerDatentypFuerUrsprungsfeld;
update "xxxx.db" set Ursprungsfeld = TempFeld;
alter table "xxxx.db" drop column TempFeld;
Das kannst Du dann per Query und ExecSQL ausführen. Das sollte mit der BDE funktionieren, bin mir nur nicht ganz sicher, ob das Column erforderlich ist oder nicht. In der Hilfe zu LocalSQL stehts in eckigen Klammern, ist also wohl optional.
  Mit Zitat antworten Zitat
Benutzerbild von SubData
SubData

Registriert seit: 14. Sep 2004
Ort: Stuhr
1.078 Beiträge
 
Delphi 11 Alexandria
 
#9

Re: TTable: Breite einer vorhandene Spalte nachträglich ände

  Alt 9. Jan 2009, 15:45
Das geht auch per TTable

// Edit: Siehe nächster Beitrag.
Ronny
/(bb|[^b]{2})/
  Mit Zitat antworten Zitat
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.323 Beiträge
 
Delphi XE2 Professional
 
#10

Re: TTable: Breite einer vorhandene Spalte nachträglich ände

  Alt 9. Jan 2009, 15:46
Bei "CreateTable" wird aber die komplette vorhandene Tabelle überschrieben und alle Daten sind weg
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  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 07:54 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