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 1 von 3  1 23      
sancho1980

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

fuzzy matches via sql

  Alt 30. Apr 2006, 18:24
Datenbank: firebird • Version: 2.0 • Zugriff über: ibx, ibexpert
hallo
ich habe eine frage,
stellt euch folgende sql-abfrage vor:
select * from tabelle where feld = x angenommen, die ergebnismenge ist leer; kann ich meine select-abfrage irgendwie abändern, so dass ich trotzdem noch wenigsten denjenigen datensatz zurückbekomme, dessen feld-wert von allen am nächsten an x dran ist?
danke,
martin
Um Rekursion zu verstehen, muss man zunächst Rekursion verstehen.
  Mit Zitat antworten Zitat
Benutzerbild von Catbytes
Catbytes

Registriert seit: 7. Sep 2002
Ort: Heckendalheim
353 Beiträge
 
Delphi XE5 Enterprise
 
#2

Re: fuzzy matches via sql

  Alt 30. Apr 2006, 18:26
Zitat von sancho1980:
hallo
ich habe eine frage,
stellt euch folgende sql-abfrage vor:
select * from tabelle where feld = x angenommen, die ergebnismenge ist leer; kann ich meine select-abfrage irgendwie abändern, so dass ich trotzdem noch wenigsten denjenigen datensatz zurückbekomme, dessen feld-wert von allen am nächsten an x dran ist?
danke,
martin
Wie wäre es mit LIKE?

select * from tabelle where feld LIKE x
Catbytes
  Mit Zitat antworten Zitat
sancho1980

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

Re: fuzzy matches via sql

  Alt 30. Apr 2006, 18:35
klingt naheliegend nur leider bekomm ich da die gleiche ergebnismenge zurück wie bei '='; also leer wenn es keinen datensatz mit GENAU dem wert gibt
Um Rekursion zu verstehen, muss man zunächst Rekursion verstehen.
  Mit Zitat antworten Zitat
Klaus01

Registriert seit: 30. Nov 2005
Ort: München
5.768 Beiträge
 
Delphi 10.4 Sydney
 
#4

Re: fuzzy matches via sql

  Alt 30. Apr 2006, 18:37
wenn es sich um einen Strinwert handelt kannst Du auch mit Wildcards arbeiten.

select * from tabelle where feld LIKE %x%

Grüße
Klaus
Klaus
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#5

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 08:08
Hallo Martin,

das ist ein Standardproblem und es wird so gelöst:

SQL-Code:
/* predecessor when missing */
select * from tabelle where feld <= :x order by feld desc rows 1

/* successor when missing */
select * from tabelle where feld >= :x order by feld rows 1
Grüße vom marabu
  Mit Zitat antworten Zitat
sancho1980

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

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 09:40
Hmmm,
das is aber nicht ganz das Gleiche, weil ich da vorher wissen muss, ob ich den Vorgänger oder den Nachfolger will. Ich will aber genau denjenigen Eintrag, der am geringsten von Beiden von meinem gewünschten String entfernt ist. Wenn es irgendwie 'ne Möglichkeit gäbe, in SQL nach der Differenz zwischen zwei Strings zu fragen, dann müsstes irgendwie gehen...
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
 
#7

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 09:48
Dein Problem kannst du möglicherweise in einer SP in Verbindung mit einer SoundEx-Funktion lösen. In der SP interierst du über alle Datensätze und vergleichst den Suchstring mit dem Werten und merkst dir den Datensatz mit der höchsten Ähnlichkeit. Diesen gibst du dann zurück.
Markus Kinzler
  Mit Zitat antworten Zitat
Klaus01

Registriert seit: 30. Nov 2005
Ort: München
5.768 Beiträge
 
Delphi 10.4 Sydney
 
#8

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 09:54
hier ist mal ein Lin, wo über soundex diskutiert wurde
-> http://www.wer-weiss-was.de/theme165...le1718061.html
Ist nicht sehr erbaulich was dabei herauskam.

Grüße
Klaus
Klaus
  Mit Zitat antworten Zitat
sancho1980

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

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 10:11
Zitat:
In der SP interierst du über alle Datensätze und vergleichst den Suchstring mit dem Werten
Sehr rechenintensiv, oder?
Wär's nicht besser einfach nur zu schauen, OB der Datensatz da ist und wenn er NICHT da ist einfach mit Vorgänger und Nachfolger zu vergleichen und dann den mit der geringsten Differenz zurückzugeben?
Das Problem ist nur, dass ich nicht genau weiß wie ich das ausdrücken muss
ich meine wie ich so eine Stored Procedure definiere, krieg ich ja vielleicht noch raus, aber wie berechne ich die Differenz zwischen zwei Strings? Oder besser: wie bestimme ich, welcher von Zwei Strings x und y dem String z am ähnlichsten ist??

Zitat:
hier ist mal ein Lin, wo über soundex diskutiert wurde
Hab mal gegooglet was Soundex ist: Ne, sowas mein ich nicht. Es geht mir nicht darum, denjenigen Datensatz zu finden, der am ähnlichsten KLINGT, sondern den, der gemäß der in der Datenbank gesetzten Sortierreihenfolge am ähnlichsten GESCHRIEBEN wird und zwar unabhängig davon, ob's der Nachfolger oder Vorgänger ist...
Um Rekursion zu verstehen, muss man zunächst Rekursion verstehen.
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#10

Re: fuzzy matches via sql

  Alt 4. Mai 2006, 10:13
Hallo Martin,

Zitat von sancho1980:
Ich will aber genau denjenigen Eintrag, der am geringsten von Beiden von meinem gewünschten String entfernt ist. Wenn es irgendwie 'ne Möglichkeit gäbe, in SQL nach der Differenz zwischen zwei Strings zu fragen, dann müsstes irgendwie gehen...
es gibt beliebig viele Metriken zur Bestimmung des Abstandes zweier Strings. Der amerikanische Soundex-Algorithmus zielt ja nur auf den Gleichklang von Namen. Weiter verbreitet ist der Editierabstand nach Levenshtein - der Name ist auch hier in der DP schon aufgetaucht. Du solltest vielleicht mal deine Anforderungen genauer erklären - um so hilfreicher werden die Beiträge.

marabu
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 23:21 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