STV_RECENTS - Amazon Redshift

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

STV_RECENTS

Utilisez la RECENTS table STV _ pour obtenir des informations sur les requêtes actuellement actives et récemment exécutées sur une base de données.

STV_ RECENTS est visible par tous les utilisateurs. Les super-utilisateurs peuvent voir toutes les lignes, tandis que les utilisateurs standard peuvent voir uniquement leurs propres données. Pour de plus amples informations, veuillez consulter Visibilité des données dans les tables et vues système.

Certaines ou toutes les données de ce tableau se trouvent également dans la vue SYS de surveillanceSYS_QUERY_HISTORY. Les données de la vue SYS de surveillance sont formatées pour être plus faciles à utiliser et à comprendre. Nous vous recommandons d'utiliser la vue SYS de surveillance pour vos requêtes.

Résolution des problèmes avec STV _ RECENTS

STV_ RECENTS est particulièrement utile pour déterminer si une requête ou un ensemble de requêtes est en cours d'exécution ou si elle est terminée. Elle indique également la durée d’exécution d’une requête. Cela est utile pour identifier les requêtes qui prennent du temps à s’exécuter.

Vous pouvez associer STV _ RECENTS à d'autres vues du système, par exemple STV_INFLIGHT pour collecter des métadonnées supplémentaires sur l'exécution de requêtes. (Vous trouverez dans la section des exemples de requêtes un exemple qui montre comment procéder.) Vous pouvez également utiliser les enregistrements renvoyés par cette vue ainsi que les fonctionnalités de surveillance de la console Amazon Redshift pour résoudre les problèmes en temps réel.

Les vues système qui complètent STV _ RECENTS incluentSTL_QUERYTEXT, qui récupère le texte de la requête pour SQL les commandes et SVV_QUERY_INFLIGHT qui joint STV _ INFLIGHT à STL _QUERYTEXT.

Colonnes de la table

Nom de la colonne Type de données Description
userid entier ID de l’utilisateur qui a généré l’entrée.
status character(20) Statut de la requête. Les valeurs valides sont Running, Done.
starttime timestamp Heure de début de la requête.
duration entier Nombre de microsecondes depuis que la session a commencé.
user_name character(50) Nom de l’utilisateur qui a lancé le processus.
db_name character(50) Nom du moteur de la base de données.
query character(600) Texte de la requête, jusqu’à 600 caractères. Tous les caractères supplémentaires sont tronqués.
pid entier ID du processus de la session associée à la requête, qui est toujours -1 pour les requêtes qui ont été terminées.

Exemples de requêtes

Pour identifier les requêtes qui sont en cours d’exécution sur la base de données, exécutez la requête suivante :

select user_name, db_name, pid, query from stv_recents where status = 'Running';

L'exemple de sortie ci-dessous montre une seule requête exécutée sur la TICKIT base de données :

user_name | db_name | pid | query ----------+---------+---------+------------- dwuser | tickit | 19996 |select venuename, venueseats from venue where venueseats > 50000 order by venueseats desc;

L’exemple suivant renvoie la liste des requêtes (le cas échéant) qui sont en cours d’exécution ou qui se trouvent dans une file d’attente en attendant d’être exécutées :

select * from stv_recents where status<>'Done'; status | starttime | duration |user_name|db_name| query | pid -------+---------------------+----------+---------+-------+-----------+------ Running| 2010-04-21 16:11... | 281566454| dwuser |tickit | select ...| 23347

Cette requête ne renvoie pas de résultats, sauf si vous exécutez un certain nombre de requêtes simultanées et que certaines d’entre elles se trouvent dans une file d’attente.

L’exemple suivant développe l’exemple précédent. Dans ce cas, les requêtes qui sont vraiment « en cours d’exécution » (pas en attente) sont exclues du résultat :

select * from stv_recents where status<>'Done' and pid not in (select pid from stv_inflight); ...

Pour obtenir des conseils supplémentaires sur la résolution des problèmes liés aux performances des requêtes, consultez Résolution des problèmes de requêtes.