Foros del Web » Programando para Internet » PHP »

Select between datetimes PHP-Mysql

Estas en el tema de Select between datetimes PHP-Mysql en el foro de PHP en Foros del Web. Hola a todos. Antes de nada decir que he buscado en el foro y no he encontrado ninguna respuesta al tema exacto que me ocupa. ...
  #1 (permalink)  
Antiguo 07/08/2009, 12:04
Avatar de Nietzsche  
Fecha de Ingreso: enero-2005
Ubicación: MALAGA-ESPAÑA
Mensajes: 228
Antigüedad: 19 años, 10 meses
Puntos: 0
Select between datetimes PHP-Mysql

Hola a todos. Antes de nada decir que he buscado en el foro y no he encontrado ninguna respuesta al tema exacto que me ocupa. Como se trata de una mezcla entre PHP y Mysql tampoco se si se encuentra en la seccion adecuada.

Simplemente necesito saber si la fecha actual en la que un usuario introduce unos datos esta entre dos fechas almacenadas en BD.

Pongo el codigo:

Código PHP:
  $momento time(); // Capturamos el momento actual
  
$momento date'Y-m-d H:i:s'$momento); // Lo pasamos a formato MySQL

$sql "SELECT Id FROM premios WHERE '$momento' between horai and horaf"//Buscamos si esta en un momento ganador 
Los campos horai y horaf son datetimes con dia y hora

El caso es que no me funciona, he probado de varias maneras. Alguien sabe como se haria esta comparacion en la query de forma correcta?

Muchas gracias.
__________________
Salud y libertad
  #2 (permalink)  
Antiguo 07/08/2009, 12:47
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años, 5 meses
Puntos: 1517
Respuesta: Select between datetimes PHP-Mysql

Para poder verificar tiene que ser algo asi

Código PHP:
Ver original
  1. $sql = "SELECT Id FROM premios WHERE horai <= '".$momento."' and horaf >= '".$momento."'";

Ahi verifica si $momento esta entre medio de las dos fechas
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #3 (permalink)  
Antiguo 07/08/2009, 12:55
 
Fecha de Ingreso: mayo-2006
Ubicación: Bogotá
Mensajes: 2.061
Antigüedad: 18 años, 6 meses
Puntos: 50
Respuesta: Select between datetimes PHP-Mysql

Si horai y horaf son dos campos de la tabla seria asi:

select count(*) from premios Where horai<=$momento and horaf>=$momento

o expliqueme mejro para ayudarle.

Edito

Se me adelanto abimael
  #4 (permalink)  
Antiguo 07/08/2009, 13:37
Avatar de Nietzsche  
Fecha de Ingreso: enero-2005
Ubicación: MALAGA-ESPAÑA
Mensajes: 228
Antigüedad: 19 años, 10 meses
Puntos: 0
Respuesta: Select between datetimes PHP-Mysql

Mmm, esa fue mi primera opcion....

La probé y no me va.
Me genera la siguiente query:

SELECT Id FROM premios WHERE horai <= '1249673485' and horaf >= '1249673485'

pero no me da ningun resultado y si que tengo un premio en la bd para el dia de hoy dentro de esta hora....
__________________
Salud y libertad
  #5 (permalink)  
Antiguo 07/08/2009, 13:45
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años, 5 meses
Puntos: 1517
Respuesta: Select between datetimes PHP-Mysql

lo que sucede es que tienes lo tienes declarado en segundos y necesitas cambiarlo al formato en que se guarda la base de datos. Me imagino que el formato que tienes en la base de datos es asi YYYY-MM-DD HH:MM:SS

Por lo tanto cuando vayas a trabajarlo tienes que hacerlo de esta forma
Código PHP:
Ver original
  1. $d = date("Y-m-d H:i:s");
  2. $sql = "SELECT Id FROM premios WHERE horai <= '".$d."' and horaf >= '".$d."'";
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #6 (permalink)  
Antiguo 07/08/2009, 13:57
Avatar de Nietzsche  
Fecha de Ingreso: enero-2005
Ubicación: MALAGA-ESPAÑA
Mensajes: 228
Antigüedad: 19 años, 10 meses
Puntos: 0
Respuesta: Select between datetimes PHP-Mysql

Es cierto, habia comentado esa linea (en mi primer post la tenia OK)

Aun asi me devuelve la siguiente query pero sigue sin funcionar!!:

SELECT Id FROM premios WHERE horai <= '2009-08-07 21:56:49' and horaf >= '2009-08-07 21:56:49'
__________________
Salud y libertad
  #7 (permalink)  
Antiguo 07/08/2009, 14:18
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años, 5 meses
Puntos: 1517
Respuesta: Select between datetimes PHP-Mysql

Ahora mismo cree una tabla usando phpMyAdmin el formato con que la cree fue esto
Código sql:
Ver original
  1. DROP TABLE IF EXISTS `t`;
  2. CREATE TABLE IF NOT EXISTS `t` (
  3.   `ID` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT,
  4.   `datetime` TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00',
  5.   `datetime2` TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00',
  6.   PRIMARY KEY (`ID`)
  7. ) ENGINE=MyISAM;
  8.  
  9. --
  10. -- Volcar la base de datos para la tabla `t`
  11. --
  12.  
  13. INSERT INTO `t` (`ID`, `datetime`, `datetime2`) VALUES
  14. (1, '2009-08-07 00:00:00', '2009-08-07 18:00:00');


e hice este query en esa tabla

Código sql:
Ver original
  1. SELECT *
  2.   FROM  `t`
  3.   WHERE  `datetime` <=  '2009-08-07 16:17:20' AND  `datetime2` >=  '2009-08-07 16:17:20';

Y me trajo el resultado
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #8 (permalink)  
Antiguo 08/08/2009, 04:16
Avatar de Nietzsche  
Fecha de Ingreso: enero-2005
Ubicación: MALAGA-ESPAÑA
Mensajes: 228
Antigüedad: 19 años, 10 meses
Puntos: 0
Respuesta: Select between datetimes PHP-Mysql

Muchas gracias abimaelrc

Reescribí el código de 0 con tus indicaciones y ahora si funciona!
La verdad no se donde estaba el fallo porque tengo la impresión de que lo tenia igual, pero algo se me escaparía....

Gracias!
__________________
Salud y libertad
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 22:38.