Foros del Web » Programando para Internet » PHP »

Error en PHP

Estas en el tema de Error en PHP en el foro de PHP en Foros del Web. Hola, Tengo el siguiente código que me da el error que veis abajo. Me podéis echar un cable? Código PHP: $result2  =  mysql_query ( "SELECT *, DATEDIFF(fecha, CURDATE()) diasfaltan FROM horarios WHERE CURDATE() BETWEEN DATE_SUB(fecha, INTERVAL 7 DAY) AND fecha ORDER BY fecha, diasfaltan" ...
  #1 (permalink)  
Antiguo 28/12/2009, 20:51
 
Fecha de Ingreso: noviembre-2008
Mensajes: 259
Antigüedad: 15 años, 5 meses
Puntos: 1
Error en PHP

Hola,

Tengo el siguiente código que me da el error que veis abajo. Me podéis echar un cable?
Código PHP:
$result2 mysql_query("SELECT *, DATEDIFF(fecha, CURDATE()) diasfaltan FROM horarios WHERE CURDATE() BETWEEN DATE_SUB(fecha, INTERVAL 7 DAY) AND fecha ORDER BY fecha, diasfaltan");
$busqueda mysql_fetch_array($result2); 
foreach(
$busqueda as $k => $v$busqueda[$k] = substr($v0strlen($v) - 3); 
Warning: Invalid argument supplied for foreach() in C:\wamp\www\OH\horarios\tablaLateralHorarios.php on line 28
  #2 (permalink)  
Antiguo 28/12/2009, 21:11
Avatar de McBlink  
Fecha de Ingreso: noviembre-2006
Ubicación: $ARG->LaPampa()
Mensajes: 1.694
Antigüedad: 17 años, 5 meses
Puntos: 23
Respuesta: Error en PHP

no soy de usar mucho los foreach por lo que no estoy seguro en lo qeu te voy a responder, pero creo que este bucle recorre los array de ésta forma:

Código PHP:
$array= array(
   
"uno" => 1,
   
"dos" => 2
si alguno sabe si se puede recorrer una consulta directamente como esta ahí bienvenido sea, aprenderemos algo nuevo

Saludos.
  #3 (permalink)  
Antiguo 28/12/2009, 21:12
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Error en PHP

antes de utilizar tu variable $busqueda procura debugearla con var_dump() para que veas el tipo de variable que es...

en este caso, se necesita de un array()
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #4 (permalink)  
Antiguo 28/12/2009, 21:13
 
Fecha de Ingreso: noviembre-2008
Mensajes: 259
Antigüedad: 15 años, 5 meses
Puntos: 1
Respuesta: Error en PHP

Lo que no entiendo es que el FOREACH funcionaba perfectamente antes que había una consulta MYSQL más simple, pero con esta consulta que he puesto ahí no funciona, muy extraño.

El FOREACH quita el :00 de los segundos del campo date que viene de la base de datos.

Alguna idea sobre el error?
  #5 (permalink)  
Antiguo 28/12/2009, 21:20
 
Fecha de Ingreso: diciembre-2009
Mensajes: 438
Antigüedad: 14 años, 4 meses
Puntos: 16
Respuesta: Error en PHP

Has comprobado que la consulta te devuelva algún resultado?
  #6 (permalink)  
Antiguo 28/12/2009, 21:22
 
Fecha de Ingreso: noviembre-2008
Mensajes: 259
Antigüedad: 15 años, 5 meses
Puntos: 1
Respuesta: Error en PHP

el $busqueda no me devuelve nada.
  #7 (permalink)  
Antiguo 28/12/2009, 21:24
 
Fecha de Ingreso: diciembre-2009
Mensajes: 438
Antigüedad: 14 años, 4 meses
Puntos: 16
Respuesta: Error en PHP

Pues probablemente el $result2 tampoco. Quizá al modificar la consulta hay alguna condición que no se cumple con los resultados que quieres obtener.
  #8 (permalink)  
Antiguo 28/12/2009, 21:40
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Error en PHP

entonces, hay que depurar la consulta...
Código PHP:
mysql_query(/* tu consulta */) or die(mysql_error()); 
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #9 (permalink)  
Antiguo 28/12/2009, 22:03
Avatar de jackson666  
Fecha de Ingreso: noviembre-2009
Ubicación: Buenos Aires, Argentina
Mensajes: 1.971
Antigüedad: 14 años, 5 meses
Puntos: 65
Respuesta: Error en PHP

Asi no funca?

Código PHP:
$otroArray = array();

foreach(
$busqueda as $k => $v){

/** Justamente con el foreach lo que haces es 
  * "olvidarte" de tu array original. Esto asi como 
  * lo tenes esta mal me parece...
  * $busqueda[$k] = substr($v, 0, strlen($v) - 3);
  * Fijate que a $busquedas lo estas iterando, para que
  * le asignas valores nuevamente? Si queres hacer eso, 
  * declara otro array... */

$otroArray[$k] = substr($v0strlen($v) - 3);


__________________
HV Studio
Diseño y desarrollo web
  #10 (permalink)  
Antiguo 28/12/2009, 22:12
 
Fecha de Ingreso: noviembre-2008
Mensajes: 259
Antigüedad: 15 años, 5 meses
Puntos: 1
Respuesta: Error en PHP

Arreglado, esa fecha no existía en mi bbdd.

Era una tontería, pero en vez de no mostrarme nada, me mostraba un error.

Gracias
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 16:00.