CAST()
parece que solo funciona para BINARY, CHAR, DATE; DATETIME, DECIMAL, TIME, SIGNED, UNSIGNED.¿Cómo echo un tipo a bigint en MySQL?
necesito para convertir una cadena hexadecimal a un bigint, es decir, que me gustaría:
SELECT CAST(CONV("55244A5562C5566354',16,10) AS BIGINT)
CONV() devuelve una cadena, así que por eso estoy tratando el convertido él. Tengo 2 utiliza para estos datos Inserción
, por ejemplo
INSERT INTO a(foo) SELECT CONV(bar,16,10) FROM ...
Aquí foo es una columna de letra grande, barra un varchar. Tal vez podría salirse con la instrucción Select siendo una cadena y dejar que MySQL se ocupe de ella (?)Devolver datos donde el cliente aprenderá dinámicamente el tipo de datos de la columna,
SELECT CONV(bar,16,10)
no es bueno ya que el cliente manejarlo como una cadena.
¿Entonces eso lo convierte en un bigint/lo que sea? No tengo que preocuparme por desbordar un entero "normal". – Anonym
@Anonym: en '5.1',' CAST ... AS UNSIGNED' siempre da como resultado 'BIGINT'. – Quassnoi
¿Está documentado en alguna parte? – will