创建是/否即布尔字段时,从访问数据库或一般转换的最佳实践是什么?


当前回答

可以使用BIT字段

创建新表:

CREATE TABLE Tb_Table1
(
ID              INT,
BitColumn       BIT DEFAULT 1
)

在现有表中添加列:

ALTER TABLE Tb_Table1 ADD BitColumn  BIT DEFAULT 1

插入记录:

INSERT Tb_Table1 VALUES(11,0)

其他回答

BIT数据类型通常用于存储布尔值(0表示false, 1表示true)。

您可以使用位列类型。

您可以使用BIT类型,可以有1或0,如果允许使用NULL,也可以使用NULL。

BIT类型转换:

除0到1以外的任何整数值。 除“0”到1之外的任何整型字符串值。 0到0。

然后,可以创建一个BIT类型的表,如下图所示:

CREATE TABLE doctor (
  id INT IDENTITY,
  name NVARCHAR(50),
  on_call BIT, -- Here
  PRIMARY KEY(id)
)
GO

然后插入行,如下图所示:

INSERT INTO doctor 
VALUES ("John", 1), ("Tom", 0), ("Lisa", "-23"), ("Kai", "0"), ("Bob", NULL)
GO
1> SELECT * FROM doctor
2> GO
id name on_call
-- ---- -------
 1 John       1 <- 1
 2 Tom        0 <- 0
 3 Lisa       1 <- "-23"
 4 Kai        0 <- "0"
 5 Bob     NULL <- NULL

创建表时的示例用法:

[ColumnName]     BIT   NULL   DEFAULT 0

已经有答案说使用比特。我会补充更多的答案。

您应该使用比特来表示布尔值。

来自MSDN文章的备注。

Bit可以取值为1、0或NULL。 SQL Server数据库引擎优化位列的存储。如果 一个表中有8个或更少的位列,这些列被存储为 1个字节。如果有从9到16位的列,列为 存储为2字节,以此类推。 字符串值TRUE和FALSE可以转换为位值:TRUE 转换为1,FALSE转换为0。 转换为位将任何非零值提升为1。 参考

注意:只有在数据类型为NOT NULL时,才将值保持为1和0是一种良好的实践

作为位有值1,0和NULL。请看真值表。所以要相应地规划价值。允许位数据类型为NULL值可能会增加混淆。

参考