Share via


NSDiagnosticSubscriptionClass (Transact-SQL)

Crea un report di diagnostica per la classe di sottoscrizione per un'applicazione Microsoft SQL Server Notification Services. Il report contiene informazioni, ad esempio sulla data e ora di esecuzione delle regole e sul recapito delle notifiche in base alla classe di sottoscrizione, utili per risolvere i problemi relativi all'elaborazione della classe di sottoscrizione.

Sintassi

[ schema_name . ] NSDiagnosticSubscriptionClass 
    [ @ApplicationName = ] 'app_name' ,
    [ @SubscriptionClassName = ] 'subscription_class_name' 
    [, [ @ReportingInterval = ] interval ] 
    [, [ @StartDateTime = ] 'start_date_time' ] 
    [, [ @EndDateTime = ] 'end_date_time' ] 

Argomenti

[ @ApplicationName = ] 'app_name'

Nome di un'applicazione definito nel file di configurazione. app_name è di tipo nvarchar(255) e non prevede alcun valore predefinito.

[ @SubscriptionClassName = ] 'subscription_class_name'

Nome della classe di sottoscrizione definito nel file di definizione dell'applicazione (ADF). subscription_class_name è di tipo nvarchar(255) e non prevede alcun valore predefinito.

[ @ReportingInterval = ] interval

Numero di quantum del generatore per ogni intervallo di report. Il report contiene una riga per intervallo. interval è di tipo int e il valore predefinito è 1, che indica un quantum del generatore per intervallo.

La durata del quantum viene definita nel file di definizione dell'applicazione (ADF).

[ @StartDateTime = ] 'start_date_time'

Data e ora UTC (Coordinated Universal Time o ora di Greenwich) di inizio del report. start_date_time è di tipo datetime. Il valore predefinito è @EndDateTime - (5 * QuantumDuration * @ReportingInterval). Utilizzando il valore predefinito, il set dei risultati contiene al massimo cinque righe, ognuna delle quali rappresenta un intervallo di report.

[ @EndDateTime = ] 'end_date_time'

Data e ora UTC di fine del report. end_date_time è di tipo datetime. Il valore predefinito è l'ora UTC in cui viene richiamata la stored procedure.

Set di risultati

Nome colonna Tipo di dati Descrizione

IntervalStartDateTime

datetime

Data e ora UTC di inizio per l'intervallo di report.

IntervalEndDateTime

datetime

Data e ora UTC di fine per l'intervallo di report.

SubscriptionsScheduledCount

int

Numero di sottoscrizioni pianificate elaborate durante l'intervallo di report.

AvgScheduledSubscriptionWaitTime

float

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il tempo di attesa medio tra l'ora pianificata per la sottoscrizione e l'ora effettiva di elaborazione della sottoscrizione.

AvgScheduledNotificationGenerationTime

float

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il tempo medio richiesto dal generatore per creare dati di notifica non elaborati in base alle sottoscrizioni pianificate.

AvgScheduledSubscriptionRuleFiringTime

float

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il tempo medio necessario per eseguire la regola di sottoscrizione pianificata.

ScheduledNotificationBatchCount

int

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il numero di batch di notifiche creati.

ScheduledNotificationCount

int

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il numero di notifiche create.

AvgScheduledNotificationBatchWaitTillDistribution

float

Tempo medio che un batch di notifiche generato dalle sottoscrizioni pianificate durante l'intervallo di report ha dovuto attendere prima di essere prelevato dal server di distribuzione.

ScheduledNotificationDeliveryAttempts

int

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il numero di tentativi di recapito delle notifiche.

ScheduledNotificationSuccessfulDeliveries

int

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il numero di recapiti di notifiche eseguiti senza errori.

ScheduledNotificationFailedAttempts

int

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il numero di tentativi di recapito delle notifiche non riusciti.

ScheduledNotificationsDeliveryNotAttempted

int

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il numero di tentativi di recapito delle notifiche non ancora eseguiti.

ScheduledNotificationsNotYetDelivered

int

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il numero di notifiche non ancora recapitate perché non è stato effettuato alcun tentativo di recapito o perché si sono verificati problemi durante il tentativo.

ScheduledNotificationToMessageRatio

float

Per le sottoscrizioni pianificate per l'elaborazione durante l'intervallo, è il rapporto tra le notifiche generate e i messaggi inviati.

AvgScheduledNotificationBatchSucceedDeliveryTime

float

Per il recapito digest o multicast, è possibile includere più notifiche in un unico messaggio. Questa colonna indica il numero medio di notifiche incluse nei messaggi digest o multicast.

Osservazioni

Notification Services crea la stored procedure NSDiagnosticSubscriptionClass nel database dell'istanza quando viene creata l'istanza. Quando si aggiorna l'istanza, Notification Services ricompila la stored procedure.

Questa stored procedure è disponibile nello schema dell'istanza, specificato dall'elemento SchemaName del file di configurazione dell'istanza (ICF). Se non si specifica un nome di schema, viene utilizzato lo schema predefinito dbo.

Le sottoscrizioni pianificate rientrano nell'intervallo di report quando la data e ora di esecuzione della regola pianificate sono maggiori del valore di IntervalStartDateTime e minori o uguali al valore di IntervalEndDateTime.

Per stabilire la data e l'ora UTC correnti, eseguire SELECT GETUTCDATE() in SQL Server Management Studio. L'ora UTC corrente viene calcolata in base all'ora locale corrente e all'impostazione del fuso orario del sistema operativo del computer in cui è in esecuzione SQL Server.

Autorizzazioni

Le autorizzazioni di esecuzione vengono assegnate per impostazione predefinita ai membri del ruolo di database NSAnalysis, del ruolo predefinito del database db_owner e del ruolo predefinito del server sysadmin.

Valori restituiti

0 (esito positivo) o 1 (esito negativo)

Esempi

A. Impostazione dei valori dell'intervallo di report, dell'ora di inizio e dell'ora di fine

Nell'esempio seguente viene illustrato come creare il report di diagnostica della classe di sottoscrizione per l'applicazione Flight e la classe di sottoscrizione FlightNotifications. L'istanza utilizza le impostazioni predefinite del database, che prevedono l'inserimento di tutti gli oggetti dell'istanza nello schema dbo.

Il report include 50 quantum del generatore per ogni intervallo di report. Il report inizia alle 17.00 del 23 maggio 2004 e finisce alle 18.00 dello stesso giorno:

EXEC dbo.NSDiagnosticSubscriptionClass 
    @ApplicationName = N'Flight', 
    @SubscriptionClassName = N'FlightSubscriptions', 
    @ReportingInterval = 50, 
    @StartDateTime = '2004-05-23 17:00', 
    @EndDateTime = '2004-05-23 18:00';

B. Utilizzo dei valori predefiniti, schema denominato

Nell'esempio seguente viene illustrato come creare il report di diagnostica della classe di sottoscrizione per l'applicazione Flight e la classe di sottoscrizione FlightNotifications. In questo esempio, la stored procedure (come tutti gli altri oggetti dell'istanza) è inclusa nello schema FlightInstance, come specificato nell'elemento SchemaName del file di configurazione dell'istanza (ICF).

Per il report vengono utilizzati i valori predefiniti, che specificano di visualizzare i dati della classe di sottoscrizione relativi agli ultimi cinque quantum del generatore.

EXEC FlightInstance.NSDiagnosticSubscriptionClass 
    @ApplicationName = N'Flight', 
    @SubscriptionClassName = N'FlightSubscriptions';

Vedere anche

Riferimento

Stored procedure di Notification Services (Transact-SQL)

Altre risorse

Report sulle prestazioni di Notification Services
SchemaName Element (ICF)

Guida in linea e informazioni

Assistenza su SQL Server 2005