Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment puis-je convertir un int en bit dans MySQL 5.1 ?

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 !!!