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

CASE dans MySQL force le type de données de la colonne à BIGINT au lieu de INT

L'astuce suivante peut vous aider :

DELIMITER //

CREATE FUNCTION `return_integer`(`number` INT UNSIGNED)
RETURNS INT UNSIGNED DETERMINISTIC
BEGIN
    RETURN `number`;
END//

DELIMITER ;

SELECT
    CASE `L`.`Code`
       WHEN 'ABCD' THEN `return_integer`(0)
       ELSE `L`.`ID`
    END AS XLID
FROM `table_name` `L`;