Mysql
 sql >> Database >  >> RDS >> Mysql

Come trovare le occorrenze delle parole più popolari in MySQL?

Puoi estrarre parole con alcune manipolazioni di stringhe. Supponendo che tu abbia una tabella di numeri e che le parole siano separate da spazi singoli:

select substring_index(substring_index(r.title, ' ', n.n), ' ', -1) as word,
       count(*)
from results r join
     numbers n
     on n.n <= length(title) - length(replace(title, ' ', '')) + 1
group by word;

Se non disponi di una tabella numerica, puoi costruirne una manualmente utilizzando una sottoquery:

from results r join
     (select 1 as n union all select 2 union all select 3 union all . . .
     ) n
     . . .

SQL Fiddle (per gentile concessione di @GrzegorzAdamKowalski) è qui .