在Microsoft SQL Server中有布尔数据类型吗?

如果不是,在MS SQL Server的替代方案是什么?


当前回答

SQL Server中存在布尔数据类型。取值为TRUE、FALSE或UNKNOWN。然而,布尔数据类型只是包含比较运算符(例如=,<>,<,>=)或逻辑运算符(例如AND, or, IN, EXISTS)组合的布尔表达式的结果。布尔表达式只允许出现在少数几个地方,包括CASE表达式的WHERE子句、HAVING子句、WHEN子句或IF或WHILE流控制语句的谓词。

对于所有其他用法,包括表中列的数据类型,不允许使用布尔值。对于其他用途,首选BIT数据类型。它的行为类似于一个缩小的INTEGER,只允许值0、1和NULL,除非进一步限制为NOT NULL列约束或CHECK约束。

要在布尔表达式中使用BIT列,需要使用比较操作符进行比较,例如=,<>或IS NULL。如。

SELECT
    a.answer_body
FROM answers AS a
WHERE a.is_accepted = 0;

从格式化的角度来看,位值在客户端软件中通常显示为0或1。当需要更用户友好的格式时,它不能在数据库前的应用层处理,可以使用CASE表达式“及时”转换。

SELECT
    a.answer_body,
    CASE a.is_accepted WHEN 1 THEN 'TRUE' ELSE 'FALSE' END AS is_accepted
FROM answers AS a;

将布尔值存储为字符数据类型(如char(1)或varchar(5))也是可能的,但这不是很清楚,有更多的存储/网络开销,并且需要每个列上的CHECK约束来限制非法值。

作为参考,答案表的模式类似于:

CREATE TABLE answers (
    ...,
    answer_body nvarchar(MAX) NOT NULL,
    is_accepted bit NOT NULL DEFAULT (0)
);

其他回答

SQL Server中存在布尔数据类型。取值为TRUE、FALSE或UNKNOWN。然而,布尔数据类型只是包含比较运算符(例如=,<>,<,>=)或逻辑运算符(例如AND, or, IN, EXISTS)组合的布尔表达式的结果。布尔表达式只允许出现在少数几个地方,包括CASE表达式的WHERE子句、HAVING子句、WHEN子句或IF或WHILE流控制语句的谓词。

对于所有其他用法,包括表中列的数据类型,不允许使用布尔值。对于其他用途,首选BIT数据类型。它的行为类似于一个缩小的INTEGER,只允许值0、1和NULL,除非进一步限制为NOT NULL列约束或CHECK约束。

要在布尔表达式中使用BIT列,需要使用比较操作符进行比较,例如=,<>或IS NULL。如。

SELECT
    a.answer_body
FROM answers AS a
WHERE a.is_accepted = 0;

从格式化的角度来看,位值在客户端软件中通常显示为0或1。当需要更用户友好的格式时,它不能在数据库前的应用层处理,可以使用CASE表达式“及时”转换。

SELECT
    a.answer_body,
    CASE a.is_accepted WHEN 1 THEN 'TRUE' ELSE 'FALSE' END AS is_accepted
FROM answers AS a;

将布尔值存储为字符数据类型(如char(1)或varchar(5))也是可能的,但这不是很清楚,有更多的存储/网络开销,并且需要每个列上的CHECK约束来限制非法值。

作为参考,答案表的模式类似于:

CREATE TABLE answers (
    ...,
    answer_body nvarchar(MAX) NOT NULL,
    is_accepted bit NOT NULL DEFAULT (0)
);

在SQL Server中可以使用Bit DataType来存储布尔数据。

你正在寻找一点。它存储1或0(或NULL)。

或者,你可以使用字符串'true'和'false'来代替1或0,就像这样-

declare @b1 bit = 'false'
print @b1                    --prints 0

declare @b2 bit = 'true'
print @b2                    --prints 1

此外,任何非0的值(无论是正的还是负的)计算为1(或在某些情况下转换为1)。

declare @i int = -42
print cast(@i as bit)    --will print 1, because @i is not 0

注意,SQL Server使用了三种值逻辑(true, false和NULL),因为NULL是bit数据类型的一个可能值。以下是相关的真值表

更多关于三值逻辑的信息

SQL Server中三值逻辑的例子

http://www.firstsql.com/idefend3.htm

https://www.simple-talk.com/sql/learn-sql-server/sql-and-the-snare-of-three-valued-logic/

我使用TINYINT(1)数据类型,以存储布尔值在SQL Server虽然BIT是非常有效的

SQL Server使用Bit数据类型