^ (Bitwise Exclusive OR) (Transact-SQL)

Berlaku untuk:SQL ServerAzure SQL DatabaseAzure SQL Managed InstanceAzure Synapse Analytics AnalyticsPlatform System (PDW)Titik akhir analitik SQL di Microsoft FabricWarehouse di Microsoft Fabric

Melakukan operasi OR eksklusif bitwise antara dua nilai bilangan bulat.

Konvensi sintaks transact-SQL

Sintaksis

expression ^ expression  

Catatan

Untuk melihat sintaks Transact-SQL untuk SQL Server 2014 (12.x) dan versi yang lebih lama, lihat Dokumentasi versi sebelumnya.

Argumen

expression
Adalah ekspresi valid dari salah satu jenis data dari kategori jenis data bilangan bulat, atau bit, atau jenis data biner atau varbinary. ekspresi diperlakukan sebagai angka biner untuk operasi bitwise.

Catatan

Hanya satu ekspresi yang dapat berupa jenis data biner atau varbinary dalam operasi bitwise.

Jenis Hasil

int jika nilai input adalah int.

smallint jika nilai input kecil.

tinyint jika nilai inputnya kecil.

Keterangan

Operator ^ bitwise melakukan OR eksklusif logis bitwise di antara kedua ekspresi, mengambil setiap bit yang sesuai untuk kedua ekspresi. Bit dalam hasil diatur ke 1 jika bit (tetapi tidak keduanya) (untuk bit saat ini yang diselesaikan) dalam ekspresi input memiliki nilai 1. Jika kedua bit adalah 0 atau kedua bit adalah 1, bit dalam hasil dibersihkan ke nilai 0.

Jika ekspresi kiri dan kanan memiliki jenis data bilangan bulat yang berbeda (misalnya, ekspresi kiri berwarna kecil dan ekspresi kanan adalah int), argumen jenis data yang lebih kecil dikonversi ke jenis data yang lebih besar. Dalam hal ini, ekspresi smallintdikonversi ke int.

Contoh

Contoh berikut membuat tabel menggunakan tipe data int untuk menyimpan nilai asli dan menyisipkan dua nilai ke dalam satu baris.

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

Kueri berikut melakukan OR eksklusif bitwise pada a_int_value kolom dan b_int_value .

SELECT a_int_value ^ b_int_value  
FROM bitwise;  
GO  

Berikut adalah hasilnya:

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

Representasi biner 170 (a_int_value atau A) adalah 0000 0000 1010 1010. Representasi biner 75 (b_int_value atau B) adalah 0000 0000 0100 1011. Melakukan operasi OR eksklusif bitwise pada kedua nilai ini menghasilkan hasil 0000 0000 1110 0001biner , yaitu desimal 225.

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

Lihat Juga

Ekspresi (Transact-SQL)
Operator (Transact-SQL)
Operator Bitwise (Transact-SQL)
^= (Bitwise Exclusive OR Assignment) (Transact-SQL)
Operator Majemuk (Transact-SQL)