Как добавить функцию levenshtein в mysql?




user-defined-functions levenshtein-distance (3)

связанный с сетью веб-сайт мертв. Кстати, код создания функции здесь:

DELIMITER $$

CREATE FUNCTION levenshtein( s1 varchar(255), s2 varchar(255) ) returns int deterministic 
BEGIN 
  DECLARE s1_len, 
    s2_len, 
    i, 
    j, 
    c, 
    c_temp, 
    cost          int; 
  declare s1_char char; 
  -- max strlen=255 
  declare cv0, 
    cv1 varbinary(256); 
  set s1_len = char_length(s1), 
    s2_len = char_length(s2), 
    cv1 = 0x00, 
    j = 1, 
    i = 1, 
    c = 0; 
  if s1 = s2 THEN 
  RETURN 0; 
elseif s1_len = 0 THEN 
  RETURN s2_len; 
elseif s2_len = 0 THEN 
  RETURN s1_len; 
  else 
  WHILE j <= s2_len do 
  SET cv1 = concat(cv1, unhex(hex(j))), 
    j = j + 1; 
endWHILE;WHILE i <= s1_len do 
SET s1_char = substring(s1, i, 1), 
  c = i, 
  cv0 = unhex(hex(i)), 
  j = 1;WHILE j <= s2_len do 
SET c = c + 1;IF s1_char = Substring(s2, j, 1) then 
SET cost = 0; 
else 
SET cost = 1;ENDIF;SET c_temp = conv(hex(substring(cv1, j, 1)), 16, 10) + cost;IF c > c_temp then
SET c = c_temp;ENDIF;SET c_temp = conv(hex(substring(cv1, j+1, 1)), 16, 10) + 1;IF c > c_temp then
SET c = c_temp;ENDIF;SET cv0 = concat(cv0, unhex(hex(c))), 
  j = j + 1;ENDWHILE;SET cv1 = cv0, 
  i = i + 1;ENDWHILE;ENDIF;RETURN c;
END;

DELIMITER ;

Надеюсь, это поможет кому-то!

Я получил код для levenshtein distance для формы mysql «http://kristiannissen.wordpress.com/2010/07/08/mysql-levenshtein/», но как добавить эту функцию в mysql? Я использую xampp, и мне нужно его для поиска в php.


Я подключился к моему серверу MySQL и просто выполнил этот оператор в MySQL Workbench , и он просто работал - теперь у меня есть новая функция levenshtein() .

Например, это работает так, как ожидалось:

SELECT levenshtein('abcde', 'abced')

2

  • Войдите в базу данных mysql через phpmyadmin или через терминал.
  • щелкните по sql.

  • добавьте разделитель $$ в свою функцию в приведенной выше ссылке и в конце разделителя; ,

  • один раз, если он успешно скомпилирован, вы можете использовать его в этой базе данных там, где хотите, как внутри других процедур или функций или запросов и т. д.!






levenshtein-distance