& (Bitwise AND) (Transact-SQL)

Aplica-se a:SQL ServerBanco de Dados SQL do AzureInstância Gerenciada de SQL do AzureAzure Synapse AnalyticsPDW (Analytics Platform System)Ponto de extremidade de SQL no Microsoft FabricWarehouse no Microsoft Fabric

Executa uma operação lógica AND bit a bit entre dois valores inteiros.

Convenções de sintaxe de Transact-SQL

Sintaxe

expression & expression  

Observação

Para exibir a sintaxe do Transact-SQL para o SQL Server 2014 (12.x) e versões anteriores, confira a Documentação das versões anteriores.

Argumentos

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

Observação

Em uma operação bit a bit, apenas uma expression pode ser do tipo de dados binary ou varbinary.

Tipos de resultado

int se os valores de entrada são int.

smallint se os valores de entrada são smallint.

tinyint se os valores de entrada são tinyint ou bit.

Comentários

O operador de bit a bit & executa um AND lógico bit a bit entre as duas expressões, tomando cada bit correspondente para ambas as expressões. Os bits no resultado são definidos como 1 se e somente se os dois bits (para o bit atual a ser resolvido) nas expressões de entrada tiverem um valor de 1; caso contrário, o bit no resultado será definido como 0.

Se as expressões à esquerda e à direita tiverem tipos de dados inteiros diferentes (por exemplo, a expression à esquerda é smallint e a expression à direita é int), o argumento do tipo de dados menor será convertido no tipo de dados maior. Nesse caso, a smallintexpression é convertida em um int.

Exemplos

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

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

Esta consulta executa o AND bit a bit nas colunas a_int_value e b_int_value.

SELECT a_int_value & b_int_value  
FROM bitwise;  
GO  

Este é o conjunto de resultados:

-----------   
10            
  
(1 row(s) affected)  

A representação binária de 170 (a_int_value ou A) é 0000 0000 1010 1010. A representação binária de 75 (b_int_value ou B) é 0000 0000 0100 1011. A execução da operação AND bit a bit nesses dois valores produz o resultado binário 0000 0000 0000 1010, que é o decimal 10.

(A & B)  
0000 0000 1010 1010  
0000 0000 0100 1011  
-------------------  
0000 0000 0000 1010  

Consulte Também

Expressões (Transact-SQL)
Operadores (Transact-SQL)
Operadores bit a bit (Transact-SQL)
&= (Bitwise E Atribuição) (Transact-SQL)
Operadores compostos (Transact-SQL)