• Empleos
  • Sobre nosotros
  • Empleos
    • Inicio
    • Empleos
    • Cursos y retos
  • Empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

177
Vistas
¿Interpretar la columna MySQL como una unidad de intervalo de fecha?

Al usar funciones de fecha y hora en MySQL, como DATE_ADD , ¿es posible almacenar la unidad INTERVALO en una columna y usarla en una consulta?

Por ejemplo, considere la siguiente tabla:

 +---------------------------+---------------------------------------------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +---------------------------+---------------------------------------------------+------+-----+---------+----------------+ | snapshotSchedule_entry_id | int(10) unsigned | NO | PRI | NULL | auto_increment | | snapshotSchedule_id | int(10) unsigned | NO | PRI | NULL | | | everyFrequency | smallint(5) unsigned | NO | | NULL | | | everyInterval | enum('minute','hour','day','week','month','year') | NO | | NULL | | | afterFrequency | smallint(5) unsigned | NO | | NULL | | | afterInterval | enum('minute','hour','day','week','month','year') | NO | | NULL | | +---------------------------+---------------------------------------------------+------+-----+---------+----------------+

La siguiente consulta funciona bien, porque solo trata con la expresión INTERVALO:

 select * from snapshotSchedule_entry order by date_add(now(), interval everyFrequency month);

Cuando quiero tratar con la unidad de intervalo (por ejemplo, mes, año, etc.), no lo interpreta.

mysql> select * from snapshotSchedule_entry order by date_add(now(), interval 1 everyInterval);ERROR 1064 (42000): Tiene un error en su sintaxis SQL; consulte el manual que corresponde a la versión de su servidor MySQL para conocer la sintaxis correcta para usar cerca de 'everyInterval)' en la línea 1

No me sorprende este comportamiento, solo tengo curiosidad por saber si es posible hacer que esto funcione. No es el fin del mundo hacer esto en código, pero me pregunto si es posible.

over 3 years ago · Santiago Trujillo
1 Respuestas
Responde la pregunta

0

MySQL no es tan flexible con las expresiones de intervalo. Necesitaría una expresión de case grande con valores codificados:

 order by case everyInterval when 'minute' then now() + inteval everyFrequency minute when 'hour' then now() + inteval everyFrequency hour when 'day' then now() + inteval everyFrequency day when 'week' then now() + inteval everyFrequency week when 'month' then now() + inteval everyFrequency month when 'year' then now() + inteval everyFrequency year end

Una alternativa más sencilla sería rediseñar su esquema para almacenar el intervalo con frecuencias fijas, digamos segundos y meses. Entonces podrías hacer:

 order by now() + interval everyFrequencySecond second + interval everyFrequencyMonth month
over 3 years ago · Santiago Trujillo Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda