~ (NOT bit per bit) (Transact-SQL)

Si applica a:SQL Server database SQL di Azure Istanza gestita di SQL di Azure Azure Synapse Analytics AnalyticsPlatform System (PDW)SQL analytics endpoint in Microsoft FabricWarehouse in Microsoft Fabric

Esegue un'operazione con NOT logico bit per bit su un valore integer.

Convenzioni di sintassi Transact-SQL

Sintassi

~ expression  

Nota

Per visualizzare la sintassi Transact-SQL per SQL Server 2014 (12.x) e versioni precedenti, vedere la documentazione delle versioni precedenti.

Argomenti

expression
Qualsiasi espressione valida di qualsiasi tipo di dati della categoria Integer o del tipo di dati bit, binary o varbinary. expression viene considerato un numero binario per l'operazione bit per bit.

Nota

In un'operazione bit per bit un solo valore expression può avere il tipo di dati binary o varbinary.

Tipi restituiti

int se i valori di input sono int.

smallint se i valori di input sono smallint.

tinyint se i valori di input sono tinyint.

bit se i valori di input sono bit.

Osservazioni:

L'operatore bit per bit ~ esegue un'operazione con NOT logico bit per bit per expression, valutando ogni bit in serie. Se expression ha un valore pari a 0, i bit nel set di risultati vengono impostati su 1; in caso contrario, i bit del risultato vengono impostati su 0. In altre parole, i bit a uno vengono cambiati in zero e i bit a zero vengono modificati in uno.

Importante

Per l'esecuzione di qualsiasi operazione bit per bit, la lunghezza di archiviazione dell'espressione utilizzata nell'operazione è un fattore importante. È consigliabile utilizzare lo stesso numero di byte per l'archiviazione dei valori. Ad esempio, il numero di byte del valore archiviato corrispondente al valore decimale 5 risulta diverso a seconda che 5 venga archiviato come valore di tipo tinyint, smallint o int. Infatti tinyint archivia i dati usando 1 byte, smallint archivia i dati usando 2 byte e int archivia i dati usando 4 byte. Un'operazione bit per bit su un valore decimale di tipo int, pertanto, restituisce risultati diversi rispetto a quelli di una conversione diretta binaria o esadecimale, soprattutto nel caso dell'operatore ~ (NOT bit per bit). L'operazione con NOT bit per bit potrebbe essere eseguita su una variabile di lunghezza inferiore. In questo caso, quando la variabile di lunghezza inferiore viene convertita in una variabile con tipo di dati di lunghezza maggiore, i bit negli 8 bit superiori potrebbero non essere impostati sul valore previsto. È pertanto consigliabile convertire la variabile del tipo di dati di lunghezza minore nel tipo di dati di lunghezza maggiore ed eseguire quindi l'operazione NOT sul valore risultante.

Esempi

Nell'esempio seguente viene creata una tabella con il tipo di dati int per l'archiviazione dei valori e i due valori vengono inseriti in un'unica riga.

CREATE TABLE bitwise (  
  a_int_value INT NOT NULL,  
  b_int_value INT NOT NULL); 
GO  
INSERT bitwise VALUES (170, 75);  
GO  

Nella query seguente viene eseguita l'operazione con NOT bit per bit sulle colonne a_int_value e b_int_value.

SELECT ~ a_int_value, ~ b_int_value  
FROM bitwise;  

Set di risultati:

--- ---   
-171  -76   
  
(1 row(s) affected)  

La rappresentazione binaria di 170 (a_int_value o A) è 0000 0000 0000 0000 0000 0000 1010 1010. L'esecuzione dell'operazione con NOT bit per bit su questo valore genera il risultato binario 1111 1111 1111 1111 1111 1111 0101 0101, corrispondente al valore decimale 171. La rappresentazione binaria di 75 è 0000 0000 0000 0000 0000 0000 0100 1011. L'esecuzione dell'operazione con NOT bit per bit genera il risultato 1111 1111 1111 1111 1111 1111 1011 0100, ovvero il valore decimale -76.

 (~A)     
         0000 0000 0000 0000 0000 0000 1010 1010  
         ---------------------------------------  
         1111 1111 1111 1111 1111 1111 0101 0101  
(~B)     
         0000 0000 0000 0000 0000 0000 0100 1011  
         ---------------------------------------  
         1111 1111 1111 1111 1111 1111 1011 0100  

Vedi anche

Espressioni (Transact-SQL)
Operatori (Transact-SQL)
Operatori bit per bit (Transact-SQL)