Compter le nombre de fois qu'un mot a été dit

J’ai été curieux de vérifier les tendances d’utilisation de mots spécifiques sur mon forum, existe-t-il une requête que je pourrais utiliser pour voir combien de fois une sous-chaîne a été mentionnée par semaine ?

Trouvé un qui fonctionne avec l’aide de ChatGPT

WITH date_series AS (
  SELECT generate_series(
           DATE_TRUNC('week', MIN(created_at)),  -- Début de la première semaine
           DATE_TRUNC('week', MAX(created_at)),  -- Début de la dernière semaine
           '1 week'::interval                    -- Intervalle hebdomadaire
         ) AS week_start
  FROM posts
),
posts_with_substring AS (
  SELECT
    DATE_TRUNC('week', created_at) AS week_start,
    COUNT(*) AS total_posts,
    SUM((LENGTH(raw) - LENGTH(REPLACE(lower(raw), lower('your_substring'), ''))) / LENGTH('your_substring')) AS substring_count
  FROM
    posts
  WHERE
    raw ILIKE '%test%'
  GROUP BY
    DATE_TRUNC('week', created_at)
)
SELECT
  ds.week_start,
  COALESCE(pws.total_posts, 0) AS total_posts
FROM
  date_series ds
LEFT JOIN
  posts_with_substring pws ON ds.week_start = pws.week_start
ORDER BY
  ds.week_start

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.