Partilhar via


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

Executa uma operação lógica NOT bit a bit em um valor inteiro.

Ícone de vínculo de tópicoConvenções de sintaxe Transact-SQL

Sintaxe

~ expression

Argumentos

  • expression
    É qualquer expressão válida de qualquer um dos tipos de dados da categoria de tipo de dados inteiro, ou dos tipos de dados bit, binary ou varbinary. expression é tratada como um número binário para a operação bit a bit.

    ObservaçãoObservação

    Apenas uma expression pode ser do tipo de dados binary ou varbinary em uma operação bit a bit.

Tipos de resultado

int se os valores de entrada forem int.

smallint se os valores de entrada forem smallint.

tinyint se os valores de entrada forem tinyint.

bit se os valores de entrada forem bit.

Comentários

O operador bit a bit ~ executa um NOT lógico bit a bit para a expression, obtendo um bit por vez. Se expression tiver o valor 0, os bits no conjunto de resultados serão definidos como 1; caso contrário, o bit no resultado será limpo com o valor 0. Em outras palavras, uns são alterados para zeros e zeros são alterados para uns.

Observação importanteImportante

Ao executar qualquer tipo de operação bit a bit, o comprimento do armazenamento da expressão usada na operação bit a bit é importante. Recomenda-se usar esse mesmo número de bytes ao armazenar valores. Por exemplo, o armazenamento do valor decimal 5 como tinyint, smallint ou int produz um valor armazenado com diferentes números de bytes: tinyint armazena dados usando 1 byte; smallint usa 2 bytes e int usa 4 bytes. Portanto, executar uma operação bit a bit em um valor decimal int pode produzir resultados diferentes do que usar uma conversão binária ou hexadecimal direta, especialmente quando o operador ~ (NOT bit a bit) é usado. A operação NOT bit a bit pode ocorrer em uma variável de um comprimento mais curto. Nesse caso, quando o comprimento mais curto for convertido em uma variável de tipo de dados mais longo, os bits nos 8 bits superiores podem não ser definidos com o valor esperado. Recomenda-se converter a variável de tipo de dados menor no tipo de dados maior e depois executar a operação NOT no resultado.

Exemplos

O exemplo a seguir cria uma tabela usando o tipo de dados int para armazenar os valores e insere os dois valores em uma linha.

USE tempdb;
GO
IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES 
    WHERE TABLE_NAME = 'bitwise')
DROP TABLE bitwise;
GO
CREATE TABLE bitwise
( 
a_int_value int NOT NULL,
b_int_value int NOT NULL
);
GO
INSERT bitwise VALUES (170, 75);
GO

A consulta a seguir executa o NOT bit a bit nas colunas a_int_value e b_int_value.

USE tempdb;
GO
SELECT ~ a_int_value, ~ b_int_value
FROM bitwise;

Aqui está o conjunto de resultados:

--- --- 
-171  -76 

(1 row(s) affected)

A representação binária de 170 (a_int_value ou A) é 0000 0000 1010 1010. A execução da operação NOT bit a bit nesse valor produz o resultado binário 1111 1111 0101 0101, que é o decimal -171. A representação binária de 75 é 0000 0000 0100 1011. A execução da operação NOT bit a bit produz 1111 1111 1011 0100, que é o decimal -76.

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