AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken [MySQL] Select ... where any like '%foo%'? Oder so?
Thema durchsuchen
Ansicht
Themen-Optionen

[MySQL] Select ... where any like '%foo%'? Oder so?

Ein Thema von Medium · begonnen am 9. Aug 2011 · letzter Beitrag vom 9. Aug 2011
Antwort Antwort
Alloc

Registriert seit: 18. Apr 2005
Ort: Griesheim
167 Beiträge
 
Delphi 2006 Professional
 
#1

AW: [MySQL] Select ... where any like '%foo%'? Oder so?

  Alt 9. Aug 2011, 09:59
Hi,

du könntest natürlich mal im Sourcecode von phpMyAdmin schauen, wie die das machen. Dort gibt es ja auch eine Suche über mehrere Tabellen nach einem Suchstring in beliebigen Spalten.

Grüße,
Chris
Christian Illy
ONI2.net, basicly every important link about Oni.
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.688 Beiträge
 
Delphi 2007 Enterprise
 
#2

AW: [MySQL] Select ... where any like '%foo%'? Oder so?

  Alt 9. Aug 2011, 11:08
Ich glaube, ich bin mit meiner jetzigen Variante recht zufrieden. Für mehrere tausend Zeilen könnte das sicherlich etwas lahm werden, aber es erfüllt zumindest die Aufgabe "finde den längenmäßig besten Match zu einem String, der den Feldwert enthält oder wo der Feldwert im String enthalten ist, in der Tabelle X aus allen Textspalten":
Delphi-Quellcode:
var
  fields: TStringList;
  tableName, fieldName, suchString: String;
  i: Integer;
begin
  fields := TStringList.Create;
  try
    Qry.SQL.Text := 'DESCRIBE `'+tableName+'`';
    Qry.Open;
    while not Qry.Eof do
    begin
      typeName := Qry.FieldByName('Type').AsString;
      if (Pos('char', typeName)>0) or (Pos('text', typeName)>0) then
        fields.Add(Qry.FieldByName('Field').AsString);
      Qry.Next;
    end;
    Qry.Close;

    Qry.SQL.Clear;
    for i := 0 to fields.Count-1 do
    begin
      Qry.SQL.Add('(SELECT id, ABS(CHAR_LENGTH(`'+fields[i]+'`)-'+IntToStr(Length(suchString))+') lendiff, '''+fields[i]+''' colname FROM `'+tableName+'` WHERE '+
                  'INSTR(`'+fields[i]+'`, '''+suchString+''')>0 OR INSTR('''+suchString+''', `'+fields[i]+'`)>0) ')
      if i<fields.Count-1 then
        Qry.SQL.Add('UNION ');
    end;
    Qry.SQL.Add(' ORDER BY lendiff ASC LIMIT 1');
    Qry.Open;
    if Qry.RecordCount > 0 then
    begin
      gesuchteSpalte := Qry.FieldByName('colname').AsString;
      gesuchteID := Qry.FieldByName('id').AsInteger;
    end;
  finally
    fields.Free;
  end;
end;
Falls des mal wer brauchen kann. Vorsicht ist allerdings bei Strings geboten, die Sonderzeichen beinhalten. Da wäre Umstricken auf Parameter sicherlich sinnig, in meinem Fall entsprechen sie ursprungsbedingt immer schon nur gültigen Bezeichnern ohne Sonderkrams.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)

Geändert von Medium ( 9. Aug 2011 um 11:18 Uhr)
  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 05:43 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-2025 by Thomas Breitkreuz