Transact SQL:选择一个布尔表达式

时间:2010-03-02 20:34:29

标签: sql sql-server tsql

查询:

SELECT TOP 1 ReportInvoked , EmailSent
  FROM tblReportInvoker 
 WHERE WebUserId = 12345

这给了我两位值。我真正想要的是一个标量结果,它是这两个值的逻辑和。这可能吗?这似乎很容易,但我找不到可行的语法。

编辑:当然,我聪明的计划中的缺陷是,如果两个进程都失败,那么它将是真的,因此将查询修改为:

SELECT TOP 1 (ReportInvoked & EmailSent) & (1 & ReportInvoked) AS 'ReportSent'
FROM tblReportInvoker 
WHERE WebUserId = 12345

1 个答案:

答案 0 :(得分:7)

SELECT TOP 1 ReportInvoked & EmailSent AS ReportSent FROM tblReportInvoker WHERE WebUserId = 12345

Bitwise AND operator in Transact-SQL