AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Index zuweisen

Ein Thema von Werwurm · begonnen am 29. Apr 2003 · letzter Beitrag vom 2. Mai 2003
Antwort Antwort
Werwurm

Registriert seit: 21. Apr 2003
Ort: Bremen
71 Beiträge
 
Delphi 2009 Professional
 
#1

Index zuweisen

  Alt 29. Apr 2003, 20:35
Hallo,

hänge mal wieder an einem Problem. Ich möchte während der Laufzeit eine Paradox Tabelle erstellen, was aúch geklappt hat.
Jetzt muss ich nur noch einen Index zuweisen, der 3 Felder beinhaltet.
Ich habe es aber nicht geschafft mehr als ein Feld zuzuweisen.

Bisher siehts folgendermaßen aus:
Delphi-Quellcode:
  with Form1.Table1.IndexDefs do begin
    clear;
    Add('Primary', 'Nummer', [ixPrimary, ixUnique]);
    Add('Sort', 'Interpret', [ixCaseInsensitive]);
    end;
Ich wäre für eine Hilfe sehr dankbar!!
Gruß
Marcus
  Mit Zitat antworten Zitat
hacki

Registriert seit: 15. Nov 2002
96 Beiträge
 
Delphi XE5 Professional
 
#2
  Alt 2. Mai 2003, 15:36
Hallo WerWurm,

habe das Erstellen und Handling mit Paradox-Tabellen über SQL gelöst. Dazu habe ich folgende Funktion geschrieben und mit einem TQuery-Objekt (keißt hier im Quelltext DB_CreateQuery) verknüpft:

Code:
procedure TMainForm.ExecSQLStatement( SQLStatement : String );
begin
 DB_CreateQuery.Active := FALSE;
 DB_CreateQuery.SQL.Clear;

 DB_CreateQuery.SQL.Add( SQLStatement );

  try
   DB_CreateQuery.Prepare;
   try
    DB_CreateQuery.ExecSQL;
   except
    DB_CreateQuery.SQL.Clear;
    MessageDlg('Problem bei der SQL-Ausführung (Error by ExecSQL), Routine ExecSQLStatement in Main.pas' +#13+#13+
               '"'+ SQLStatement + '"', mtError, [mbOK], 0);
   end;
  except
   DB_CreateQuery.SQL.Clear;
   MessageDlg('Problem bei der SQL-Ausführung (Error by Prepare), Routine ExecSQLStatement in Main.pas' +#13+#13+
               '"'+ SQLStatement + '"', mtError, [mbOK], 0);
  end;

 DB_CreateQuery.Active := FALSE;
end;
Dann kann ich das Erstellen der Tabellen und Indexe als SQL-Befehl folgendermaßen im Programm los werden:

Tabelle anlegen:
Code:
ExecSQLStatement('CREATE TABLE Uebungen' +
       '( '+
          'UebClient             INTEGER, '+
          'UebNummerManuell      INTEGER, '+
          'UebBibliothek         CHARACTER(1), '+
          'UebBereich            CHARACTER(30), '+
          'UebBereichNummer      SMALLINT, '+
          'UebAnzahlMin          SMALLINT, '+
          'UebAnzahlMax          SMALLINT, '+
          'UebTrainingsPhase     SMALLINT, '+
          'UebTPhaseString       CHARACTER(16), '+
          'UebSchwierigkeit      SMALLINT, '+
          'UebDauer              NUMERIC(10,2), '+
          'UebBezeichnung        CHARACTER(60), '+
          'UebZiel               BLOB(240,1), '+
          'UebBeschreibung       BLOB(240,1), '+
          'UebVariation          BLOB(240,1), '+
          'UebFeldDaten          BLOB(50,1), '+
          'PRIMARY KEY (UebClient)'+
       ' )' );
und das Anlegen von Sekundär Indizes:

Code:
ExecSQLStatement('CREATE INDEX'+
                   ' UBereich ON ''Uebungen.db'' (UebBereichNummer)' );
Ich hoffe, das hilft Dir und Du kannst das verwenden.

Grüsse
Hacki
Es ist nicht gesagt, daß es besser wird, wenn es anders wird! Wenn es aber besser werden soll, muß es anders werden! ** There are 10 different types of people in this world; those who understand binary numbers and those who don’t !
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#3
  Alt 2. Mai 2003, 16:28
Hallo Werwurm,

ich denke, es liegt daran, dass du nur Sekundärindices erzeugen kannst, wenn es auch einen Primary Key gibt. Der Primary Key hat aber keinen Namen, er muss mit:

Delphi-Quellcode:
 with Form1.Table1.IndexDefs do begin
    clear;
    Add('', 'Nummer', [ixPrimary, ixUnique]);
    Add('Sort', 'Interpret', [ixCaseInsensitive]);
    end;
definiert werden. Dann sollte es klappen!?
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
Werwurm

Registriert seit: 21. Apr 2003
Ort: Bremen
71 Beiträge
 
Delphi 2009 Professional
 
#4
  Alt 2. Mai 2003, 22:22
Hallo Hacki,

danke für Deine Antwort.
Der SQL-Code hat geklappt!!
Gruß
Marcus
  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 17:55 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