Cronologia note utente

:memo: Questa query recupera e formatta le note dell’utente dalla tabella ‘plugin_store_rows’, associando ogni nota al rispettivo ID utente, data di creazione, contenuto e ID del creatore. Il risultato è un elenco completo di note utente con dettagli pertinenti.


WITH user_notes AS (

    SELECT 
        REPLACE(key, 'notes:', '')::int AS user_id,
        notes.value->>'created_at' AS created_at,
        notes.value->>'raw' AS user_note,
        notes.value->>'created_by' AS created_by
    FROM plugin_store_rows,
    LATERAL json_array_elements(value::json) notes
    WHERE plugin_name = 'user_notes'
    ORDER BY 2 DESC 
)

SELECT 
    un.user_id,
    un.created_at::date,
    un.user_note,
    un.created_by AS created_by_user_id
FROM user_notes un
  JOIN users u ON u.id = un.user_id

7 Mi Piace