AGB  ·  Datenschutz  ·  Impressum  







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

STRING SUCHE!

Ein Thema von thomasvonmuenster1 · begonnen am 6. Mai 2004 · letzter Beitrag vom 7. Mai 2004
Antwort Antwort
thomasvonmuenster1

Registriert seit: 19. Mär 2004
132 Beiträge
 
Delphi 7 Enterprise
 
#1

STRING SUCHE!

  Alt 6. Mai 2004, 14:40
In DBMemofeld eine String suche mit sonderzeichen(* oder ?).
Delphi-Quellcode:
procedure TForm1.Button2Click(Sender: TObject);
begin
 timer4.Enabled:=false;
 IBQuery4.SQL.Text:='select titel,datei from tabelle1 where memofeld like ''%'+ComboBox2.Text+'%''';
 IBQuery4.Open;
end;
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

Re: STRING SUCHE!

  Alt 6. Mai 2004, 14:42
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von sakura
sakura

Registriert seit: 10. Jun 2002
Ort: München
11.412 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: STRING SUCHE!

  Alt 6. Mai 2004, 14:46
Nur Großbuschtaben in der Überschrift sind unerwünscht. Sofort ändern, sonst zu

......
Daniel W.
Ich bin nicht zurück, ich tue nur so
  Mit Zitat antworten Zitat
thomasvonmuenster1

Registriert seit: 19. Mär 2004
132 Beiträge
 
Delphi 7 Enterprise
 
#4

Re: STRING SUCHE!

  Alt 6. Mai 2004, 14:56
In meinen Bsp. oben vergleicht er nur den Text in der ComboBox2.Text mit den Einträgen im DBMemofeld.
Er soll nun mit * suchen.
Bsp. arbeits*
Anzeige: arbeitsrecht
arbeitsschuhe
arbeitskleidung....
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#5

Re: STRING SUCHE!

  Alt 6. Mai 2004, 15:05
Datenbankfelder vom Datentyp LOB (=Large Object) können nicht in einer
SQL-Anweisung mit like, =, <> abgefragt werden.
Möglich, dass manche Datenbanken da eine Ausnahme machen, aber man kann sich nicht
darauf verlassen.
Du könntest nun die Tabelle linear durchsuchen, das Memo-Feld mit dem Muster vergleichen,
die gefundenen Treffer (nur die Primärschlüssel) dir in einer Liste merken.
Danach wird eine Abfrage erzeugt:
SELECT * FROM Tabelle WHERE PrimaerSchluesselFeld in [Treffer1 , Treffer2, ...] Oder du erweiterst dein Datenbankdesign so, dass eine Volltextsuche in einem Memofeld
nicht nötig ist. Man kann z.B. zusätzl. Suchwörter in einem normalen Charfeld speichern.
Andreas
  Mit Zitat antworten Zitat
Robert_G
(Gast)

n/a Beiträge
 
#6

Re: STRING SUCHE!

  Alt 6. Mai 2004, 15:09
Dafür gibt es doch CLOBs (Character Large Object), die kann man fast wie einen Varchar2 behandeln.
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.251 Beiträge
 
Delphi 2006 Professional
 
#7

Re: STRING SUCHE!

  Alt 6. Mai 2004, 15:14
Zitat von thomasvonmuenster1:
...Er soll nun mit * suchen.
Dann nehme das '%' aus dem Querystring und setze den Suchtext von "Hand" Stichwort -> StringReplace
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Udontknow

Registriert seit: 17. Jun 2002
223 Beiträge
 
#8

Re: STRING SUCHE!

  Alt 7. Mai 2004, 11:39
In Interbase kann man mit "containing" Text-Blobs durchsuchen. Ist natürlich nicht indiziert.

Cu,
Udontknow
  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 11:52 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