在Microsoft SQL Server中有布尔数据类型吗?
如果不是,在MS SQL Server的替代方案是什么?
在Microsoft SQL Server中有布尔数据类型吗?
如果不是,在MS SQL Server的替代方案是什么?
当前回答
我使用TINYINT(1)数据类型,以存储布尔值在SQL Server虽然BIT是非常有效的
其他回答
使用Bit数据类型。在本地T-SQL中处理它时,它的值为1和0
您可以使用BIT数据类型来表示布尔数据。BIT字段的值可以是1、0或null。
你正在寻找一点。它存储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 DataType来存储布尔数据。