^ (位元互斥 OR) (Transact-SQL)
適用於:SQL Server Azure SQL 資料庫 Azure SQL 受控執行個體 Azure Synapse Analytics Analytics Platform System (PDW) Microsoft Fabric 的 SQL 端點分析 Microsoft Fabric 的倉儲
在兩個整數值之間,執行位元互斥 OR 運算。
語法
expression ^ expression
引數
expression
這是整數資料類型類別目錄之任何資料類型或是 bit、binary 或 varbinary 資料類型的任何有效運算式。 expression 會被視為適用於位元運算的二進位數字。
注意
在位元運算中,只能有一個 expression 是 binary 或 varbinary 資料類型。
結果類型
如果輸入值為 int,則為 int。
如果輸入值為 smallint,則為 smallint。
如果輸入值為 tinyint,則為 tinyint。
備註
^ 位元運算子會在兩個運算式之間執行位元邏輯排除 OR 運算,其中會針對兩個運算式拿取每個對應的位元。 如果輸入運算式的其中一個位元 (針對目前所解析的位元) 的值是 1 (兩個位元值不能同時是 1),結果中的兩個位元都會設為 1。 如果兩個位元同時是 0 或同時是 1,便會清除結果中的位元而成為 0 值。
如果左右運算式的整數資料類型不同 (例如,左邊的 expression 是 smallint,而右邊的 expression 是 int),就會將較小資料類型的引數轉換為較大的資料類型。 在此情況下, smallint 運算式 會 轉換成 int。
範例
下列範例會使用 int 資料類型來建立資料表以儲存原始值,並將兩個值插入到單一資料列中。
CREATE TABLE bitwise (
a_int_value INT NOT NULL,
b_int_value INT NOT NULL);
GO
INSERT bitwise VALUES (170, 75);
GO
下列查詢在 a_int_value
和 b_int_value
資料行上執行位元互斥 OR 運算。
SELECT a_int_value ^ b_int_value
FROM bitwise;
GO
以下為結果集:
-----------
225
(1 row(s) affected)
170 (a_int_value
或 A
) 的二進位表示法是 0000 0000 1010 1010
。 75 (b_int_value
或 B
) 的二進位表示法是 0000 0000 0100 1011
。 對這兩個值執行位元互斥 OR 運算,會產生二進位結果 0000 0000 1110 0001
,也就是十進位的 225。
(A ^ B)
0000 0000 1010 1010
0000 0000 0100 1011
-------------------
0000 0000 1110 0001
另請參閱
運算式 (Transact-SQL)
運算子 (Transact-SQL)
位元運算子 (Transact-SQL)
^= (位元排除 OR 指派) (Transact-SQL)
複合運算子 (Transact-SQL)