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.

Booleanos en SQL Server - Tipo de dato bit

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.

Si el post ha sido de tu agrado te invito a que me sigas para saber cuando haya escrito un nuevo post, haya actualizado algún sistema o publicado un nuevo software. Facebook | X | Instagram | Telegram | También estoy a tus órdenes para cualquier contratación en mi página de contacto