|(位或)(Transact-SQL)

在 Transact-SQL 语句中,将两个指定的整数值转换为二进制表达式后执行逻辑位或运算。

主题链接图标Transact-SQL 语法约定

语法

expression | expression

参数

  • expression
    整数数据类型类别、bitbinaryvarbinary 数据类型的任何有效表达式expression 被当成用于位运算的二进制数字处理。

    ms186714.note(zh-cn,SQL.90).gif注意:
    在位运算中,只有一个 expression 可以为 binaryvarbinary 数据类型。

结果类型

如果输入值为 int 则返回 int;如果输入值为 smallint,则返回 smallint;如果输入值为 tinyint,则返回 tinyint

备注

位运算符 | 取两个表达式的每个对应位,在两个表达式之间执行逻辑位或运算。如果在输入表达式中有一个位为 1 或两个位均为 1(对于正在解析的当前位),那么结果中的位将被设置为 1;如果输入表达式中的两个位都不为 1,则结果中的位将被设置为 0。

如果左侧和右侧的表达式具有不同的整数数据类型(例如,左侧的 expression 的数据类型为 smallint,右侧的 expression 的数据类型为 int),则会将较小数据类型的参数转换为较大数据类型。在以下示例中,smallintexpression 被转换为 int

示例

以下示例将创建一个包含 int 数据类型的表以显示原始的值,并将该表放入一个行中。

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_int_value 列和 b_int_value 列执行位或运算。

USE tempdb;
GO
SELECT a_int_value | b_int_value
FROM bitwise;
GO

下面是结果集: 

----------- 
235         

(1 row(s) affected)

170(以下的 a_int_valueA)的二进制表示形式为 0000 0000 1010 1010。75(以下的 b_int_valueB)的二进制表示形式为 0000 0000 0100 1011。对这两个值执行位或运算产生的二进制结果为 0000 0000 1110 1011,即十进制数 235。

(A | B)
0000 0000 1010 1010
0000 0000 0100 1011
-------------------
0000 0000 1110 1011

请参阅

参考

运算符 (Transact-SQL)

其他资源

位运算符(数据库引擎)

帮助和信息

获取 SQL Server 2005 帮助