AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi fuzzy matches via sql
Thema durchsuchen
Ansicht
Themen-Optionen

fuzzy matches via sql

Ein Thema von sancho1980 · begonnen am 30. Apr 2006 · letzter Beitrag vom 5. Mai 2006
Antwort Antwort
Seite 2 von 3     12 3      
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#11

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 10:18
Beispiel einer einfachen Levenstein-Funktion:

Delphi-Quellcode:
function LevenshteinDistance( s: string; t: string): Integer;
var
  i, j, cost, h: Integer;
  d: array[0..255, 0..255] of integer;
  n,m: integer;
begin
   n := Length(s);
   m := Length(t);

   for i := 0 to n do
       d[i,0] := i;
   for j := 0 to m do
       d[0,j] := j;
   for i := 1 to n do
       for j := 1 to m do
       begin
           if s[i] = t[j] then cost := 0
                          else cost := 1;
           h := min(d[i-1,j ] + 1, // Einfügen
                             d[i, j-1] + 1); // Löschen
           d[i,j] := min( h,
                             d[i-1,j-1] + cost); // Ersetzen
        end;
   result := d[n,m];
end;
Wenn du diese Funktion in eine UDF verpackst, kannst du diese in einer SP verwenden.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Kedariodakon
Kedariodakon

Registriert seit: 10. Sep 2004
Ort: Mönchengladbach
833 Beiträge
 
Delphi 7 Enterprise
 
#12

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 11:56
SQL-Code:
Select Top 1 Abs( feld - x ) As Sort, * From tabelle
Order By Sort
Bye

Edit funzt zumindest solange x eine Zahl ist
Christian
  Mit Zitat antworten Zitat
sancho1980

Registriert seit: 7. Feb 2006
429 Beiträge
 
#13

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 12:16
Zitat:
Beispiel einer einfachen Levenstein-Funktion:
Cool, danke
Am elegantesten wärs natürlich wenn ich das Ganze jetz als stored procedure implementiere
geht das?
keine angst, versuch das dann selbst irgendwie zu bauen; nur mal so ne frage ob's möglich ist, (feld-)variablen in einer sp zu deklarieren...


Zitat:
zumindest solange x eine Zahl ist
was ja mal eben nicht der Fall ist
Um Rekursion zu verstehen, muss man zunächst Rekursion verstehen.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#14

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 12:23
Ich habe hier mal zum Test, die UDF und eine SP erzeugt. Ich hoffe es hilft dir.
Angehängte Dateien
Dateityp: zip levenshtein_185.zip (43,9 KB, 23x aufgerufen)
Markus Kinzler
  Mit Zitat antworten Zitat
sancho1980

Registriert seit: 7. Feb 2006
429 Beiträge
 
#15

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 12:54
cool danke,
voll nett
versuch das abend gleich mal zu installieren
evtl muss ich nochmal nerven
Um Rekursion zu verstehen, muss man zunächst Rekursion verstehen.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#16

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 14:31
Ich habe die UDF um einen Parameter erweitert und die SP angepasst.

Die UDF hat unterschiedliche Längen der beiden Strings berücksichtigt. Das in diesem Fall zu falschen Ergebnissen führen kann.

z.B.

Daten Tabelle:

ID TEXT
...
10 Gemüse
11 Z

Suchtext: gem

Es wird der Datensatz 11 zurückgeliefert da zur Umformung hier weniger Schritte notig sind als beim Datensatz 10.

Es gibt nun einen weiteren Parameter in dem den Umgang der Längen steuern kann
0: Wie bisher
1: Länge erster String ( 2. String wird ggf mit Leerzeichen aufgefüllt)
2: Länge zweiter String ( 1. String wird ggf mit Leerzeichen aufgefüllt)
3: es wird die Länge des kürzesten Strings verwendet.

Ich habe das Originalarchiv ersetzt.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Kedariodakon
Kedariodakon

Registriert seit: 10. Sep 2004
Ort: Mönchengladbach
833 Beiträge
 
Delphi 7 Enterprise
 
#17

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 15:32
Naja, das ist halt Levenshtein
Für das Problem kann man verschiedene Kosten implementieren, wass schlußendlich noch Levenshtein ist im gegensatz zu dem was du da mit dem Auffüllen machst

Levenshtein

Zudem is deine Levenshtein Funktion ein wenig naja, wenn die Zeichenketten mit mehr als 255 Zeichen bekommt, knallts...

Besser wer sicher ein dynamisches Array...

Bye Keda
Christian
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#18

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 15:39
Das ganze war auch nicht als Universal-Lösung gedacht, sondern als Beispiel wie man das lösen könnte.
Markus Kinzler
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#19

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 16:47
In Anlehnung an die Bemerkung von [user="Kedariodakon"] habe ich meine unvollständige, fehlerhaftes Test-UDF/SP nochmal überarbeitet. Auch dieses ist gewiss unvollständig und zerstörrt möglicherweise euren Rechner und ...

Die Kosten sind nun als 4. Parameter implementiert.

Ich habe wieder das Original ersetzt.
Markus Kinzler
  Mit Zitat antworten Zitat
sancho1980

Registriert seit: 7. Feb 2006
429 Beiträge
 
#20

Re: fuzzy matches via sql

  Alt 5. Mai 2006, 01:15
Hi Leute,
hab mir die Geschichte mit dem Levenshtein mal zu Gemüte geführt. Dazu 2 Fragen:

1.
Zitat:
Die Kosten sind nun als 4. Parameter implementiert.
Wieso? Die Kosten sind doch der Rückgabewert.. Was gibt's da zu übergeben?

2.
Hab mir auch mal durchgelesen wie der Algorithmus funktioniert. Interessant, dass es funktioniert; aber kapiert einer von euch wie man auf sowas kommt? Gibt's irgendwo nen Beweis, dass der Algorithmus immer das richtige Ergebnis liefert?

Gruß,

Martin
Um Rekursion zu verstehen, muss man zunächst Rekursion verstehen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 3     12 3      


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 16:43 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