AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL-Abfrage bei einer Oracle-Datenbank
Thema durchsuchen
Ansicht
Themen-Optionen

SQL-Abfrage bei einer Oracle-Datenbank

Ein Thema von O.T. · begonnen am 9. Sep 2003 · letzter Beitrag vom 11. Sep 2003
Antwort Antwort
O.T.

Registriert seit: 5. Sep 2003
Ort: München
13 Beiträge
 
#1

SQL-Abfrage bei einer Oracle-Datenbank

  Alt 9. Sep 2003, 10:04
Hi ihr alle,

von meinem letzten Beitrag müsstet ihr wissen das ich leider ein Delphi-Anfänger bin
weshalb meine Fragen vielleicht nicht wirklich schwer sind aber irgendwie komm ich nicht weiter.

Und zwar hab ich eine Tabelle "table1" mit den Spalten
1. Name vom Typ String
2. ID vom Typ integer
3. Datum vom Typ Datum (dd.mm.jjjj)


Ich suche jetzt hierzu eine Abfrage die mir eine Datensatz herausgibt wenn ich eines, zwei oder alle drei vorgegeben habe.

Leider muss ich halt eben berücksichtigen das auch zwei der drei Felder lehr sein können.

Ungefähr eine Anhnung was ich meine??

Kann mir hier vielleicht jemand ein bisschen helfen und mir eine übersichtliche Lösung nennen.

Am besten ohne viel Code zu tippen.

Wäre euch sehr verbunden bedanke mich schon im voraus

Bis dann..........................
  Mit Zitat antworten Zitat
Benutzerbild von samson
samson

Registriert seit: 26. Aug 2003
Ort: Hövelhof Riege
105 Beiträge
 
Delphi 2007 Professional
 
#2

Re: SQL-Abfrage bei einer Oracle-Datenbank

  Alt 9. Sep 2003, 11:11
Ich würde folgendermassen vorgehen:

Delphi-Quellcode:
Function TForm1.Suchen;
var
  oqQuery :TOracleQuery;
  strSQL :string;
begin
  //Dynamisch erzeugtes Query Createn
  oqQuery := TOracleQuery.Create(nil);
  try
    //Session zuweisen
    oqQuery.Session := OracleSession;

    //Ersten SQL-Text Setzen.
    oqQuery.SQL.TEXT := 'select * from adresse where ';
    
    //Where Clausel zusammenbauen
    strSQL := '';
    if self.EditName.Text <> 'then
      strSQL := strSQL + 'name like '+QuotedStr('%'+self.EditName.text+'%')+' and ';
    if self.EditID.Text <> 'then
      strSQL := strSQL + 'id = '+self.EditID.Text+' and ';
    if self.EditDatum.Text <> 'then
      StrSQL := strSQL + 'Datum = '+QuotedStr(self.EditDatum.text)+' and ';

    if pos('and', strSQL <> 0
     then strSQL := leftStr(strSQL, length(strSQL)-5)
     else oqQuery.SQL.Text := leftStr(oqQuery.SQL.Text, length(oqQuery.SQL.Text)-6);

    //SQL-Anweisung hinzufügen.
    oqQuery.SQL.Text := oqQuery.SQL.Text + strSQL;

    //SQL-Anweisung ausführen
    oqQuery.Execute;

   { Weitere Anweisungen, da ich gleich das Objekt wieder freigebe }
  finally
    oqQuery.Free;
  end;
end;
- Wie Du siehst baue ich mir hier eine SQL-Anweisung dynamisch zusammen.
- Ich arbeite persönlich mit den OracleComponenten, darum auch TOracleQuery, sollte aber bei anderen Componenten auch funktionieren.

Ich hoffe Dir geholfen zu haben.

Gruss

Samson
Frank Gellermann
Wer Informationen hat, hat Macht. Wer Macht hat, hat Informationen!!!
  Mit Zitat antworten Zitat
Alfons_G

Registriert seit: 7. Jun 2002
Ort: München
296 Beiträge
 
Delphi 2007 Architect
 
#3

Re: SQL-Abfrage bei einer Oracle-Datenbank

  Alt 9. Sep 2003, 15:43
Im Allgemeinen werden Queries mit Open geöffnet, wenn es eine SELECT-Anweisung ist. Bei DML-Anweisungen (INSERT, UPDATE, DELETE) dagegen ExecSQL bei TQuery, und Execute bei div. anderen Komponenten.

Alfons Grünewald



Alfons Grünewald
  Mit Zitat antworten Zitat
O.T.

Registriert seit: 5. Sep 2003
Ort: München
13 Beiträge
 
#4

Re: SQL-Abfrage bei einer Oracle-Datenbank

  Alt 11. Sep 2003, 15:20
Hi,

Vielen Dank dir nochmal.


Hast mir wirklich sehr geholfen.


Also nochmal....................... Dankeschön
  Mit Zitat antworten Zitat
Benutzerbild von samson
samson

Registriert seit: 26. Aug 2003
Ort: Hövelhof Riege
105 Beiträge
 
Delphi 2007 Professional
 
#5

Re: SQL-Abfrage bei einer Oracle-Datenbank

  Alt 11. Sep 2003, 17:47
Eine Hand wäscht die andere.

Mit freut es hilfreich zu sein.

Gruss


Samson

P.S. Danke für deinen Lob.
Frank Gellermann
Wer Informationen hat, hat Macht. Wer Macht hat, hat Informationen!!!
  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 07:34 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