AGB  ·  Datenschutz  ·  Impressum  







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

SQL - Volltextsuche

Ein Thema von Snyderburn · begonnen am 7. Okt 2003 · letzter Beitrag vom 7. Okt 2003
Antwort Antwort
Snyderburn

Registriert seit: 19. Sep 2003
85 Beiträge
 
Delphi 2005 Architect
 
#1

SQL - Volltextsuche

  Alt 7. Okt 2003, 07:36
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
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#2

Re: SQL - Volltextsuche

  Alt 7. Okt 2003, 07:48
'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.
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  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

Re: SQL - Volltextsuche

  Alt 7. Okt 2003, 08:24
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)+')'
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
Snyderburn

Registriert seit: 19. Sep 2003
85 Beiträge
 
Delphi 2005 Architect
 
#4

Re: SQL - Volltextsuche

  Alt 7. Okt 2003, 08:29
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
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#5

Re: SQL - Volltextsuche

  Alt 7. Okt 2003, 10:32
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)+')'
Albert
Live long and prosper


MrSpock
  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 03:49 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