SVV_QUERY_STATE - Amazon Redshift

Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.

SVV_QUERY_STATE

Utilizza SVV_QUERY_STATE per visualizzare le informazioni riguardanti il tempo di esecuzione delle query attualmente in esecuzione.

La visualizzazione SVV_QUERY_STATE contiene un sottoinsieme di dati della tabella STV_EXEC_STATE.

SVV_QUERY_STATE è visibile a tutti gli utenti. Gli utenti con privilegi avanzati visualizzano tutte le righe; gli utenti regolari visualizzano solo i propri dati. Per ulteriori informazioni, consulta Visibilità dei dati nelle tabelle e nelle viste di sistema.

Alcuni o tutti i dati di questa tabella sono definiti anche nella vista di monitoraggio SYS SYS_QUERY_DETAIL. I dati nella vista di monitoraggio SYS sono formattati in modo da essere più facili da usare e comprendere. Ti consigliamo di utilizzare la vista di monitoraggio SYS per le query.

Nota

Questa vista è disponibile solo per le query sui cluster con provisioning.

Colonne di tabella

Nome colonna Tipo di dati Descrizione
userid integer ID dell'utente che ha generato la voce.
query integer ID query. Consente di unire in join varie altre tabelle e visualizzazioni di sistema.
seg integer Numero del segmento di query in esecuzione. Una query consiste in più segmenti e ogni segmento consiste in una o più fasi. I segmenti di query possono essere eseguiti in parallelo. Ogni segmento viene eseguito in un singolo processo.
step integer Numero della fase della query in esecuzione. Una fase è l'unità più piccola del tempo di esecuzione delle query. Ogni fase rappresenta un'unità di lavoro distinta, come per esempio la scansione di una tabella, la restituzione dei risultati o l'ordinamento dei dati.
maxtime intervallo Quantità di tempo massima (in microsecondi) per l'esecuzione di questa fase.
avgtime intervallo Tempo medio (in microsecondi) per l'esecuzione di questa fase.
righe bigint Numero di righe prodotte dalla fase in esecuzione.
bytes bigint Numero di byte prodotti dalla fase in esecuzione.
cpu bigint Per uso interno.
memory bigint Per uso interno.
rate_row double precision ows-per-second Frequenza R dall'inizio della query, calcolata sommando le righe e dividendo per il numero di secondi dall'inizio della query all'ora corrente.
rate_byte double precision ytes-per-second Frequenza B dall'inizio della query, calcolata sommando i byte e dividendo per il numero di secondi dall'inizio della query all'ora corrente.
etichetta character(25) Etichetta di query: un nome per la fase, come per esempio scan o sort.
is_diskbased character(1) Se questa fase della query è in esecuzione come operazione basata su disco: true (t) o false (f). Solo determinate fasi, come hash, sort e le fasi di aggregazione, possono accedere al disco. Molti tipi di fase sono sempre eseguiti in memoria.
workmem bigint Quantità di memoria di lavoro (in byte) assegnata alla fase di query.
num_parts integer Numero di partizioni in cui una tabella di hash è divisa durante una fase di hash. Un numero positivo in questa colonna non implica che la fase di hash viene eseguita come operazione basata su disco. Verifica il valore nella colonna IS_DISKBASED per determinare se la fase di hash era basata sul disco.
is_rrscan character(1) Se true (t), indica che in questa fase è stata utilizzata la scansione a intervallo limitato. Il valore predefinito è false (f).
is_delayed_scan character(1) Se true (t), indica che in questa fase è stata utilizzata la scansione ritardata. Il valore predefinito è false (f).

Query di esempio

Determinazione del tempo di elaborazione di una query in base alla fase

La query seguente mostra quanto è durata l'esecuzione di ogni fase della query con l'ID query 279 e quante righe di dati sono state elaborate da Amazon Redshift:

select query, seg, step, maxtime, avgtime, rows, label from svv_query_state where query = 279 order by query, seg, step;

Questa query recupera le informazioni di elaborazione relative alla query 279, come mostrato nel seguente output di esempio:

query | seg | step | maxtime | avgtime | rows | label ------+---------+------+---------+---------+---------+------------------- 279 | 3 | 0 | 1658054 | 1645711 | 1405360 | scan 279 | 3 | 1 | 1658072 | 1645809 | 0 | project 279 | 3 | 2 | 1658074 | 1645812 | 1405434 | insert 279 | 3 | 3 | 1658080 | 1645816 | 1405437 | distribute 279 | 4 | 0 | 1677443 | 1666189 | 1268431 | scan 279 | 4 | 1 | 1677446 | 1666192 | 1268434 | insert 279 | 4 | 2 | 1677451 | 1666195 | 0 | aggr (7 rows)

Determinazione di eventuali query attive attualmente in esecuzione sul disco

La query seguente mostra la presenza di eventuali query attive attualmente in esecuzione sul disco:

select query, label, is_diskbased from svv_query_state where is_diskbased = 't';

Questo output di esempio mostra la presenza di eventuali query attive attualmente in esecuzione sul disco:

query | label | is_diskbased -------+--------------+-------------- 1025 | hash tbl=142 | t (1 row)