Specifiche di capacità massima per SQL Server

Si applica a: SQL Server

Questo articolo mostra le dimensioni e i numeri massimi dei diversi oggetti definiti in SQL Server 2016 (13.x) e versioni successive. Per visualizzare i limiti dell'edizione, vedere Limiti di capacità di calcolo per edizione di SQL Server.

Per SQL Server 2014 (12.x), vedere Specifiche di capacità massima per SQL Server 2014.

Oggetti del motore di database

Valori massimi dei diversi oggetti definiti nei database di SQL Server o a cui si fa riferimento nelle istruzioni Transact-SQL.

Oggetti Motore di database di SQL Server Valori massimi per SQL Server (64 bit) Informazioni aggiuntive
Dimensioni del batch 65.536 * (dimensioni del pacchetto di rete) Le dimensioni del pacchetto di rete indicano le dimensioni dei pacchetti TDS (Tabular Data Stream) usati per le comunicazioni tra le applicazioni e il motore di database relazionale. Le dimensioni predefinite del pacchetto sono pari a 4 KB. Le dimensioni dei pacchetti di rete controllano questa opzione di configurazione.
Lunghezza in byte di una stringa contenente istruzioni Transact-SQL (dimensioni batch) 65.536 * (dimensioni del pacchetto di rete) Le dimensioni del pacchetto di rete indicano le dimensioni dei pacchetti TDS (Tabular Data Stream) usati per le comunicazioni tra le applicazioni e il motore di database relazionale. La dimensione predefinita del pacchetto è 4 KB e viene controllata dall'opzione di configurazione delle dimensioni del pacchetto di rete.
Byte per ogni colonna di stringhe brevi 8.000
Byte per GROUP BY, ORDER BY 8.060
Byte per ogni chiave di indice 900 byte per un indice cluster. 1.700 byte per un indice non cluster. Per SQL Server 2014 (12.x) e versioni precedenti, tutte le versioni supportano 900 byte per tutti i tipi di indice. Il numero massimo di byte in una chiave di indice cluster non può essere maggiore di 900. Per una chiave di indice non cluster, il valore massimo è 1.700 byte.

È possibile definire una chiave usando colonne a lunghezza variabile le cui dimensioni massime superano il limite. Tuttavia, le dimensioni combinate dei dati di tali colonne non possono mai superare il limite.
In un indice non cluster, è possibile includere colonne non chiave aggiuntive che non vengono incluse nel conteggio per il limite di dimensioni della chiave. Le colonne non chiave potrebbero migliorare le prestazioni di alcune query.
Byte per ogni chiave di indice per tabelle ottimizzate per la memoria 2.500 byte per un indice non cluster. Nessun limite per un indice hash purché tutte le chiavi di indice rientrino nella riga. In una tabella ottimizzata per la memoria, un indice non cluster non può contenere colonne chiave le cui dimensioni massime dichiarate superano i 2.500 byte. È indifferente se i dati effettivi nelle colonne chiave sono minori delle dimensioni massime dichiarate.

Per una chiave di indice hash non esiste alcun limite fisico alle dimensioni.
Per gli indici delle tabelle ottimizzate per la memoria, non è disponibile alcun concetto di colonne incluse poiché tutti gli indici coprono implicitamente tutte le colonne.
Per una tabella ottimizzata per la memoria, anche se le dimensioni delle righe sono di 8,060 byte, alcune colonne a lunghezza variabile possono essere fisicamente archiviate all'esterno di tali 8,060 byte. Tuttavia, le dimensioni massime dichiarate di tutte le colonne chiave per tutti gli indici in una tabella, oltre a eventuali colonne a lunghezza fissa aggiuntive nella tabella, non devono superare 8,060 byte.
Byte per ogni chiave esterna 900
Byte per ogni chiave primaria 900
Byte per ogni riga 8.060 SQL Server supporta l'archiviazione dei dati di overflow della riga che consente di spostare colonne di lunghezza variabile all'esterno delle righe. Nel record principale viene archiviata solo una radice di 24 byte per le colonne di lunghezza variabile spostate all'esterno delle righe. Per altre informazioni, vedere Supporto per righe di grandi dimensioni.
Byte per ogni riga nelle tabelle ottimizzate per la memoria 8.060 Le tabelle ottimizzate per la memoria in SQL Server 2016 (13.x) e versioni successive supportano l'archiviazione fuori riga. Le colonne a lunghezza variabile vengono spostate all'esterno delle righe se le dimensioni massime di tutte le colonne nella tabella superano 8,060 byte. Questa azione è una decisione in fase di compilazione. Per le colonne archiviate all'esterno delle righe viene archiviato un solo riferimento a 8 byte. Per altre informazioni, vedere Dimensioni di tabelle e righe per le tabelle con ottimizzazione per la memoria.
Byte nel testo di origine di una stored procedure Minore delle dimensioni batch o 250 MB
Byte per ogni colonna varchar(max), varbinary(max), xml, text o image 2^31-1
Caratteri per ogni colonna ntext o nvarchar(max) 2^30-1
Indici cluster per tabella 1
Colonne in GROUP BY, ORDER BY Limitato solo dal numero di byte
Colonne o espressioni in un'istruzione GROUP BY WITH CUBE o GROUP BY WITH ROLLUP 10
Colonne per ogni chiave di indice 32 Se la tabella contiene uno o più indici XML, la chiave di clustering della tabella utente viene limitata a 31 colonne perché la colonna XML viene aggiunta alla chiave di clustering dell'indice XML primario. È possibile includere colonne non chiave in un indice non cluster per evitare di raggiungere il limite massimo di 32 colonne chiave. Per altre informazioni, vedere Creare indici con colonne incluse.
Colonne per ogni chiave esterna o primaria 32
Colonne per ogni istruzione INSERT 4.096
Colonne per ogni istruzione SELECT 4.096
Colonne per ogni tabella 1.024 Le tabelle con set di colonne di tipo sparse includono fino a 30.000 colonne. Vedere le informazioni sui set di colonne di tipo sparse.
Colonne per ogni istruzione UPDATE 4.096 Ai set di colonne di tipo sparse vengono applicati limiti diversi.
Colonne per ogni vista 1.024
Connessioni per ogni client Valore massimo delle connessioni configurate
Dimensione database 524.272 terabytes
Database per istanza di SQL Server 32.767
Filegroup per ogni database 32.767
Filegroup per ogni database per dati ottimizzati per la memoria 1
File per ogni database 32.767
Dimensioni di file (dati) 16 terabyte
Dimensioni del file (log) 2 terabyte
File di dati per dati ottimizzati per la memoria per ogni database 4.096 in SQL Server 2014 (12.x). Il limite è meno rigoroso per SQL Server 2016 (13.x) e versioni successive.
File differenziale per ogni file di dati per dati ottimizzati per la memoria 1
Riferimenti alla tabella della chiave esterna per ogni tabella In uscita = 253.
In ingresso = 10.000.
Per informazioni sulle restrizioni, vedere Create Foreign Key Relationships.
Lunghezza di identificatore (in caratteri) 128
Istanze per ogni computer 50 istanze in un server autonomo.

25 istanze del cluster di failover quando si usano unità di cluster condivisi come archiviazione.
50 istanze del cluster di failover con condivisioni file SMB come opzione di archiviazione.
Indici per ogni tabella ottimizzata per la memoria 999 a partire da SQL Server 2017 (14.x) e in Azure SQL Database.

8 in SQL Server 2016 (13.x) e SQL Server 2014 (12.x).
Blocchi per ogni connessione Numero massimo di blocchi per ogni server
Blocchi per ogni istanza di SQL Server Limitato solo dalla memoria Questo valore si riferisce all'allocazione di blocchi statici. I blocchi dinamici sono limitati solo dalla memoria.
Livelli di nidificazione delle stored procedure 32 Se una stored procedure accede a più di 64 database o a più di due database in interfoliazione, verrà generato un errore.
Sottoquery nidificate 32
Transazioni nidificate 4.294.967.296
Livelli di nidificazione dei trigger 32
Indici non cluster per tabella 999
Numero di espressioni distinte nella clausola GROUP BY quando è presente una delle seguenti opzioni: CUBE, ROLLUP, GROUPING SETS, WITH CUBE, WITH ROLLUP 32
Numero di set di raggruppamento generati dagli operatori nella clausola GROUP BY 4.096
Parametri per ogni stored procedure 2.100
Parametri per ogni funzionalità definita dall'utente 2.100
REFERENCES per ogni tabella 253
Righe per ogni tabella Limitato dall'archiviazione disponibile
Tabelle per ogni database Limitato dal numero totale di oggetti di un database Gli oggetti includono tabelle, viste, stored procedure, funzioni definite dall'utente, trigger, regole, impostazioni predefinite e vincoli. La somma del numero di tutti gli oggetti in un database non può essere maggiore di 2.147.483.647.
Partizioni per ogni tabella o indice partizionato 15.000
Statistiche relative a colonne non indicizzate 30.000
Tabelle per ogni istruzione SELECT Limitato solo dalle risorse disponibili
Trigger per ogni tabella Limitato dal numero di oggetti di un database Gli oggetti includono tabelle, viste, stored procedure, funzioni definite dall'utente, trigger, regole, impostazioni predefinite e vincoli. La somma del numero di tutti gli oggetti in un database non può essere maggiore di 2.147.483.647.
Connessioni utente 32.767
Indici XML 249

Oggetti applicazione livello dati di SQL Server

Valori massimi di oggetti diversi testati nelle applicazioni livello dati di SQL Server.

Oggetto applicazione livello dati (DAC) di SQL Server Valori massimi per SQL Server (64 bit) Informazioni aggiuntive
Database per ogni applicazione livello dati 1
Oggetti per ogni applicazione livello dati Limitati dal numero di oggetti in un database o dalla memoria disponibile. I tipi di oggetti inclusi nel limite sono utenti, tabelle, viste, stored procedure, funzioni definite dall'utente, tipi di dati definiti dall'utente, ruoli di database, schemi e tipi di tabella definiti dall'utente.

Oggetti di replica

Valori massimi di vari oggetti definiti in Replica di SQL Server.

Oggetto di replica di SQL Server Valori massimi per SQL Server
(64 bit)
Informazioni aggiuntive
Articoli (pubblicazione di tipo merge) 2.048
Articoli (pubblicazione snapshot o transazionale) 32.767
Colonne in una tabella (pubblicazione di tipo merge) 246 Se si utilizza il rilevamento a livello di riga per il rilevamento dei conflitti (predefinito), nella tabella di base possono essere incluse al massimo 1.024 colonne. Tuttavia, la pubblicazione deve filtrare l'articolo in modo che venga pubblicato un massimo di 246 colonne. Se viene utilizzato il rilevamento a livello di colonna, nella tabella di base possono essere incluse al massimo 246 colonne.
Colonne in una tabella (pubblicazione snapshot o transazionale di SQL Server) 1.000 La tabella di base può includere il numero massimo di colonne consentito nel database di pubblicazione (1.024 per SQL Server), ma le colonne devono essere filtrate dall'articolo se superano il numero specificato per il tipo di pubblicazione.
Colonne in una tabella (pubblicazione snapshot o transazionale di Oracle) 995 La tabella di base può includere il numero massimo di colonne consentito nel database di pubblicazione (1.024 per SQL Server), ma le colonne devono essere filtrate dall'articolo se superano il numero specificato per il tipo di pubblicazione.
Byte per una colonna utilizzata in un filtro di riga (pubblicazione di tipo merge) 1.024
Byte per una colonna utilizzata in un filtro di riga (pubblicazione snapshot o transazionale) 8.000