En algunos motores de bases de datos existe el tipo de dato booleano, boolean o bool que indican que una variable solo podrá tener dos valores: verdadero y falso.

Con este paradigma podemos ahorrar datos y almacenarlos de una buena manera, el problema es que SQL Server no tiene el tipo de dato booleano, o bueno, sí lo tiene, pero es de otra forma.
Booleanos en SQL Server
No existe el tipo de dato boolean, pero sí el tipo de dato bit. Y un bit, como todos sabemos, puede ser un 1 o un 0.
Por lo tanto, el equivalente a un dato booleano en SQL Server es el tipo bit.
Un ejemplo de bit en la creación de una tabla es el siguiente:
create table usuarios(
correo varchar(255) not null,
suscrito bit not null
);
En ese caso tenemos una lista de usuarios que opcionalmente se pueden suscribir a nuestro boletín.
Insertar bit
Para insertar un dato indicamos el 0 o 1:
insert into usuarios values
('foo@bar.baz', 0),
('staff@gmail.com', 0),
('contacto@parzibyte.me', 1),
('john.galt@atlantis.com', 1);
El número 0 es falso o FALSE, y el 1 verdadero o TRUE.
Consultar booleanos
Para consultar en donde sea TRUE o el bit esté encendido hacemos un where dato = 1, y para saber si está apagado o en false hacemos un where dato = 0 como en el ejemplo:
/*
Consultar en donde estén suscritos
*/
select * from usuarios where suscrito = 1;
/*
Consultar en donde no
*/
select * from usuarios where suscrito = 0;
Actualizar y eliminar
Se hace lo mismo, usando el símbolo = para el where o para el set.
/*
Marcar como suscrito aquellos usuarios no suscritos
*/
update usuarios set suscrito = 1 where suscrito = 0;
Para eliminar también:
/*
Eliminar usuarios que no estén suscritos
*/
delete from usuarios where suscrito = 0;
Conclusión
Hemos visto la forma de trabajar con booleanos en SQL Server a través del tipo de dato bit, un equivalente que funciona exactamente igual y que tiene únicamente dos estados: 1 o 0.