AGB  ·  Datenschutz  ·  Impressum  







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

Tabelle mit Indizies neu erstellen

Ein Thema von Angel4585 · begonnen am 24. Feb 2011 · letzter Beitrag vom 24. Feb 2011
Antwort Antwort
Angel4585

Registriert seit: 4. Okt 2005
Ort: i.d.N.v. Freiburg im Breisgau
2.199 Beiträge
 
Delphi 2010 Professional
 
#1

Tabelle mit Indizies neu erstellen

  Alt 24. Feb 2011, 12:41
Datenbank: BDE • Version: 5.2.xyz • Zugriff über: Delphi Std DB Komponenten
Hallo,

ich möchte eine Tabelle samt Indiezies neu ertsellen, so sieht mein Code dazu aus:

Delphi-Quellcode:
table1.Close;
table1.DatabaseName:=ADB;
if not table1.Exists then
  begin
  table1.CreateTable;
  table1.IndexDefs.Clear;
  table1.IndexDefs.Add('SortErledigt','ErledigtDatum',[ixDescending]);
  end;
table1.IndexName:='SortErledigt';
table1.Open;
Wenn ich das so ausführe bekomme ich bei dem Open die Meldung:
---------------------------
Fehler
---------------------------
Index does not exist.

Index: SortErledigt
---------------------------
OK
---------------------------


Wenn ich die IndexDefs vor dem CreateTable mache, kommt folgende Meldung:
---------------------------
Fehler
---------------------------
Table is not indexed.

Table does not exist.

Table: D:\Pfad\XTabelle.db

File or directory does not exist.

File: D:\Pfad\XTabelle.db
---------------------------
OK
---------------------------

Was genau mach ich falsch, das hinzufügen von Indizies ging doch über IndexDefs oder?
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Tabelle mit Indizies neu erstellen

  Alt 24. Feb 2011, 12:48
Hast Du Dir das C++-Beispiel aus dem DocWiki einmal angeschaut?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#3

AW: Tabelle mit Indizies neu erstellen

  Alt 24. Feb 2011, 12:59
Hallo,

stell' bitte mal die Indexdefinitionen vor das CreateTable.

So sind die Indexdefinitonen beim Erstellen noch nicht bekannt und können daher auch nicht berücksichtigt werden.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Tabelle mit Indizies neu erstellen

  Alt 24. Feb 2011, 13:05
Das hat er ja auch versucht.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Angel4585

Registriert seit: 4. Okt 2005
Ort: i.d.N.v. Freiburg im Breisgau
2.199 Beiträge
 
Delphi 2010 Professional
 
#5

AW: Tabelle mit Indizies neu erstellen

  Alt 24. Feb 2011, 13:09
Danke danke, so klappts:
Delphi-Quellcode:
table1.Close;
table1.DatabaseName:=ADB;
if not table1.Exists then
  begin
  table1.IndexDefs.Clear;
  with table1.IndexDefs.AddIndexDef do
    begin
    Name:='';
    Fields:='Id';
    Options:=[ixPrimary,ixUnique];
    end;
  with table1.IndexDefs.AddIndexDef do
    begin
    Name:='SortErledigt';
    Fields:='Erledigt';
    Options:=[ixCaseInsensitive];
    end;
  table1.CreateTable;
  end;
table1.IndexName:='SortErledigt';
table1.Open;
Einmal musste ich einen Primärindex definieren und dann wird eine leere Option nicht akzeptiert, also muss man da was reinschreiben, da ich nicht descending sondern ascending sortieren will, hab ich das halt mal so gelöst.
Martin Weber
Ich bin ein Rüsselmops
  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 09:59 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