Foros del Web » Programando para Internet » PHP »

Agrupar campos de db en secuencia php

Estas en el tema de Agrupar campos de db en secuencia php en el foro de PHP en Foros del Web. Buenas tardes, me estoy iniciando al mundo del php, y poco a poco lo voy pillando.. aunque claro, parece otro odioma nuevo, por las sintaxis ...
  #1 (permalink)  
Antiguo 01/08/2012, 10:53
 
Fecha de Ingreso: octubre-2005
Mensajes: 17
Antigüedad: 18 años, 6 meses
Puntos: 0
Agrupar campos de db en secuencia php

Buenas tardes, me estoy iniciando al mundo del php, y poco a poco lo voy pillando.. aunque claro, parece otro odioma nuevo, por las sintaxis y demas...

en fin.. os comento a ver si me podeis echar una mano.


tengo una consulta que guarda la los campos "fecha" esta fecha puede comparada con la de hoy, pasada, hoy, futuro. y lo que quiero es agrupar todas los registros que tengan una entrada futura me muestra cuantas de ellas hay ( si lo hay )

nose si voy bien encaminado pero la idea creo que seria algo asi..
<?php
//montamos la consulta
$sql = "SELECT fecha,COUNT(*) FROM `videos`.`fecha` DESC";
$result = mysql_query($sql) or die (mysql_error());

//llamamos los valores de los videos futuros
while ($futuros = mysql_fetch_array ($resut)) {
?>
<?php
$fechaActual =date("Y-m-d");
echo $fechaActual ; ?> : <?php echo $futuros['fecha']; ?>

<?php
{
?>


Espero haberme explicado bien.. gracias
  #2 (permalink)  
Antiguo 01/08/2012, 11:32
Avatar de h2swider  
Fecha de Ingreso: julio-2007
Ubicación: Ciudad de Buenos Aires
Mensajes: 932
Antigüedad: 16 años, 9 meses
Puntos: 194
Respuesta: Agrupar campos de db en secuencia php

Cita:
Iniciado por PitBull Ver Mensaje
Buenas tardes, me estoy iniciando al mundo del php, y poco a poco lo voy pillando.. aunque claro, parece otro odioma nuevo, por las sintaxis y demas...

en fin.. os comento a ver si me podeis echar una mano.


tengo una consulta que guarda la los campos "fecha" esta fecha puede comparada con la de hoy, pasada, hoy, futuro. y lo que quiero es agrupar todas los registros que tengan una entrada futura me muestra cuantas de ellas hay ( si lo hay )

nose si voy bien encaminado pero la idea creo que seria algo asi..
<?php
//montamos la consulta
$sql = "SELECT fecha,COUNT(*) FROM `videos`.`fecha` DESC";
$result = mysql_query($sql) or die (mysql_error());

//llamamos los valores de los videos futuros
while ($futuros = mysql_fetch_array ($resut)) {
?>
<?php
$fechaActual =date("Y-m-d");
echo $fechaActual ; ?> : <?php echo $futuros['fecha']; ?>

<?php
{
?>


Espero haberme explicado bien.. gracias

La idea esta bien, la consulta esta mal. Debes hacer un group By para poder usar el count

Código PHP:
<?php
//montamos la consulta
//asumo que haz hecho la conexion a la base de datos previamente.
$sql "SELECT fecha, COUNT(*) FROM videos group by fecha order by fecha desc";
$result mysql_query($sql) or die (mysql_error());

//la fecha actual solo necesito guardarla una vez, por eso la sacamos del while
$fechaActual =date("Y-m-d");
echo 
"Fecha actual: $fechaActual<br\><br\>";
echo 
"Fechas futuras: ";

//llamamos los valores de los videos futuros
while ($arreglo mysql_fetch_array ($resut)) {

    
//preguntamos si la fecha es mayor a la fecha actual
    
if ($arreglo['fecha'] > $fechaActual){
        echo 
$arreglo['fecha']."<br\>";
    }

}
?>
__________________
Codifica siempre como si la persona que finalmente mantedra tu código sea un psicópata violento que sabe donde vives

Última edición por h2swider; 01/08/2012 a las 12:03
  #3 (permalink)  
Antiguo 01/08/2012, 16:57
 
Fecha de Ingreso: octubre-2005
Mensajes: 17
Antigüedad: 18 años, 6 meses
Puntos: 0
Respuesta: Agrupar campos de db en secuencia php

Gracias por responder tan rapido, pero según veo y pruebo con esto sólo veo las fechas que tienen algun video pendiente de publicar, pero no veo la cantidad de videos que tiene en cada fecha futura, no?

según he visto necesitaría la sentencia sql "DISTINCT" para agrupar los valores y sacar el total de los videos pendientes de publicar, verdad?

$sql = "SELECT fecha, COUNT(DISTINCT fecha) FROM videos group by fecha order by fecha desc";
  #4 (permalink)  
Antiguo 02/08/2012, 10:23
Avatar de h2swider  
Fecha de Ingreso: julio-2007
Ubicación: Ciudad de Buenos Aires
Mensajes: 932
Antigüedad: 16 años, 9 meses
Puntos: 194
Respuesta: Agrupar campos de db en secuencia php

el distict te va a funcionar siempre y cuando la fecha no contenga horas, minutos y segundos.
__________________
Codifica siempre como si la persona que finalmente mantedra tu código sea un psicópata violento que sabe donde vives
  #5 (permalink)  
Antiguo 02/08/2012, 10:51
 
Fecha de Ingreso: octubre-2005
Mensajes: 17
Antigüedad: 18 años, 6 meses
Puntos: 0
Respuesta: Agrupar campos de db en secuencia php

Cita:
Iniciado por h2swider Ver Mensaje
el distict te va a funcionar siempre y cuando la fecha no contenga horas, minutos y segundos.
Código PHP:
// mostramos arriba de notis los dias programados
        
$sql "SELECT fecha, COUNT(DISTINCT fecha) FROM videos group by fecha order by fecha ASC";
        
$result mysql_query($sql) or die (mysql_error());

        
//la fecha actual solo necesito guardarla una vez, por eso la sacamos del while
        
$fechaActual =date("Y-m-d");
        echo 
"<b>Fecha Actual:</b> $fechaActual <p>";
        echo 
"<b>Fechas Programadas:</b> ";

        
//llamamos los valores de los videos futuros
        
while ($arreglo mysql_fetch_array ($result)) {

            
//preguntamos si la fecha es mayor a la fecha actual
            
if ($arreglo['fecha'] > $fechaActual){
        echo 
$arreglo['fecha']."()  ||  "

la idea seria que o bien saliera la fechaProxima (numero videos programados) que como que no tiene ni hora ni minutos podria funcionar el disrtict?

cómo debo sacarlo mediante un mysql_fetch_row?



ahora tengo esto
Fechas Programadas: 2012-08-03()

Como debería llamar el php para que cojiera el total del grupo de videos?

perdon por mi ignorancia..

Gracias anticipadas! :D

Etiquetas: agrupar, campos, mysql, registro, secuencia, sql
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:53.