Delen via


^ (Bitwise Exclusive OR) (Transact-SQL)

Van toepassing op:SQL ServerAzure SQL DatabaseAzure SQL Managed InstanceAzure Synapse AnalyticsAnalytics Platform System (PDW)SQL Analytics-eindpunt in Microsoft FabricMagazijn in Microsoft FabricSQL-database in Microsoft Fabric Preview

Voert een bitsgewijze exclusieve OR-bewerking uit tussen twee gehele getallen.

Transact-SQL syntaxis-conventies

Syntax

expression ^ expression  

Arguments

expression
Is een geldige expressie van een van de gegevenstypen van de categorie geheel getal, of de bit, of de binaire of varbinaire gegevenstypen. expressie wordt behandeld als een binair getal voor de bitsgewijze bewerking.

Note

Slechts één expressie kan van het binaire of varbinaire gegevenstype zijn in een bitsgewijze bewerking.

Result Types

int als de invoerwaarden int zijn.

smallint als de invoerwaarden klein zijn.

kleineint als de invoerwaarden klein zijn.

Remarks

De ^ bitwise-operator voert een bitwise logische exclusieve OR uit tussen de twee expressies, waarbij elke bijbehorende bit voor beide expressies wordt gebruikt. De bits in het resultaat worden ingesteld op 1 als een (maar niet beide) bits (voor de huidige bit die wordt omgezet) in de invoerexpressies een waarde van 1 hebben. Als beide bits 0 of beide bits 1 zijn, wordt de bit in het resultaat gewist tot een waarde van 0.

Als de linker- en rechterexpressies verschillende gegevenstypen voor gehele getallen hebben (de linkerexpressie is bijvoorbeeld klein en de rechterexpressieint), wordt het argument van het kleinere gegevenstype geconverteerd naar het grotere gegevenstype. In dit geval wordt de smallint-expressie geconverteerd naar een int.

Examples

In het volgende voorbeeld wordt een tabel gemaakt met behulp van het int-gegevenstype om de oorspronkelijke waarden op te slaan en twee waarden in één rij in te voegen.

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

De volgende query voert de bitsgewijze exclusieve OR uit op de a_int_value en b_int_value kolommen.

SELECT a_int_value ^ b_int_value  
FROM bitwise;  
GO  

Dit is de resultatenset:

-----------   
225           
  
(1 row(s) affected)  

De binaire weergave van 170 (a_int_value of A) is 0000 0000 1010 1010. De binaire weergave van 75 (b_int_value of B) is 0000 0000 0100 1011. Het uitvoeren van de bitsgewijze exclusieve OR-bewerking op deze twee waarden produceert het binaire resultaat 0000 0000 1110 0001, dat decimaal 225 is.

(A ^ B)     
         0000 0000 1010 1010  
         0000 0000 0100 1011  
         -------------------  
         0000 0000 1110 0001  

See Also

Expressions (Transact-SQL)
Operators (Transact-SQL)
Bitwise Operators (Transact-SQL)
^= (Bitwise Exclusive OR Assignment) (Transact-SQL)
Samengestelde operators (Transact-SQL)