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
.