Vous ne pouvez pas !
CAST et CONVERT ne fonctionnent que pour :
- BINAIRE[(N)]
- CAR[(N)]
- DATE
- DATETIME
- DECIMAL[(M[,D])]
- SIGNÉ [ENTIER]
- HEURE
- NON SIGNÉ [ENTIER]
Pas de place pour :BIT, BITINT, TINYINT, MEDIUMINT, BIGINT, SMALLINT, ...
Cependant, vous pouvez créer votre propre fonction cast_to_bit(n) :
DELIMITER $$
CREATE FUNCTION cast_to_bit (N INT) RETURNS bit(1)
BEGIN
RETURN N;
END
Pour l'essayer vous-même, vous pouvez créer une vue avec plusieurs conversions comme :
CREATE VIEW view_bit AS
SELECT
cast_to_bit(0),
cast_to_bit(1),
cast_to_bit(FALSE),
cast_to_bit(TRUE),
cast_to_bit(b'0'),
cast_to_bit(b'1'),
cast_to_bit(2=3),
cast_to_bit(2=2)
... puis décrivez-le !
DESCRIBE view_bit;
Et voilà!! Tout le monde est bit(1) maintenant !!!