Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi SQL - Volltextsuche (https://www.delphipraxis.net/9881-sql-volltextsuche.html)

Snyderburn 7. Okt 2003 08:36


SQL - Volltextsuche
 
Hi Leute!

Ich möchte gerne eine Volltextsuche über meine Datenbank machen! Kann mir jemand einen Rat geben, wie man das am schnellsten macht???

mfg
Snyderburn

SirThornberry 7. Okt 2003 08:48

Re: SQL - Volltextsuche
 
'select * from meineTabelle where feld1 like "' + suchwort1 + '"' and feld2 like like "' + suchwort1 + '"'

Deine Aufgabe ist da nur noch die suchwörter die in einem String vermutlich kommen auseinander zu basteln und dem entsprechend alles hinter dem where dann zu laufzeit zusammen zu stellen.

MrSpock 7. Okt 2003 09:24

Re: SQL - Volltextsuche
 
Hallo Snyderburn,

zwei Anmerkungen zu dem Vorschlag von Sir Thornberry:

Anstatt AND musst du OR benutzen, weil der Wert ja in irgendeinem beliebigen Feld vorkommen darf.
Außerdem würde ich für den Zusammenbau des Strings die Funktion QuotedStr benutzen:

Delphi-Quellcode:
SQL := 'select * from meineTabelle '+
'where (feld1 like '+QuotedStr(suchwort1)+')'+
' OR (feld2 like '+ QuotedStrsuchwort1)+')'

Snyderburn 7. Okt 2003 09:29

Re: SQL - Volltextsuche
 
Gibt es nicht noch ne einfachere Möglichkeit, wo man nicht so viel schreiben muß??? Ich habe nämlich ca. 200 Felder, die ich dann ja alle auflisten müsste! Das wird eine ziemlich große schreibarbeit und der SQL-Code wird dementsprechend auch sehr groß!

mfg
Snyderburn

MrSpock 7. Okt 2003 11:32

Re: SQL - Volltextsuche
 
Hallo Snyderburn,

eine Tabelle mit 200 Feldern in einer relationalen Datenbank ist schon eine Besonderheit.
Die Übertragung des langen SQL Strings kannst du dir ersparen, wenn du eine entsprechende StoredProcedure auf dem Server erstellst. Eine einfachere Methode gibt es wohl nicht. Du kannst aber bei der Erzeugung des SQL Codes eine Schleife einbinden. Wenn du eine z.B. TQuery Komponente benutzt, die Felder der Datenmenge über den Feldeditor hinzufügst und dann über eine Schleife darauf zugreifst:

Delphi-Quellcode:
SQL := 'select * from meineTabelle where '
for i := 0 to myQry.FieldCount-1 do
  if i > 0 then
    SQL := SQL+' OR ('+Fields[i].FieldName+' like '+QuotedStr(suchStr)+')'
  else
   SQL := SQL+'('+Fields[i].FieldName+' like '+QuotedStr(suchStr)+')'


Alle Zeitangaben in WEZ +1. Es ist jetzt 09:05 Uhr.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz