El día de hoy estaba rescribiendo o migrando un sistema (no sé cómo se le diga exactamente) que usaba SQLite a un nuevo motor de base de datos, el cual es MySQL, también conocido MariaDB.

Con SQLite se llamaba a a función STRFTIME, pero esa función no existe en MySQL. Por lo tanto me puse a buscar un equivalente al a función STRFTIME de SQLite3 en MySQL.

Equivalente a STRFTIME de SQLite3 en MySQL

Esta función de strftime me recuerda a cuando formateamos fechas en Python. Pero bueno, STRFTIME formatea una fecha, así de simple. Su sintaxis es:

select strftime("formato", columna_de_fecha)

Como lo dije, en MySQL no existe STRFTIME pero existe DATE_FORMAT. Esta función es equivalente a la de SQLite, con la diferencia de que en esta primero se pasa la columna y luego el formato.

Ejemplo de STRFTIME contra DATE_FORMAT

Vamos a crear una tabla y llenarla con datos en ambos motores:

Tabla de personas con la misma estructura

Luego insertamos datos, y para hacer la consulta en donde seleccionamos únicamente el año de la fecha (esto es, formatear la fecha) usamos la función que cada motor tiene, con resultados idénticos:

STRFTIME y DATE\_FORMAT en SQLite y MySQL

Tanto en SQLite como en MySQL, los resultados fueron los mismos. De esta forma pude modificar las llamadas a esas funciones para terminar de cambiar el motor de base de datos del sistema.

Conclusión

Te invito a leer sobre AS en MySQL. También puedes ver cómo comenzar a usar MySQL desde la terminal.

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