Foros del Web » Programando para Internet » PHP »

remplazar Null por Date()

Estas en el tema de remplazar Null por Date() en el foro de PHP en Foros del Web. Hola a todos, Hace tiempo que estoy tratando de sacar la siguiente consulta: en una tabla mysql tengo columnas con fechas, donde una fecha conocida, ...
  #1 (permalink)  
Antiguo 09/09/2008, 13:41
 
Fecha de Ingreso: septiembre-2008
Mensajes: 3
Antigüedad: 16 años, 2 meses
Puntos: 0
remplazar Null por Date()

Hola a todos,

Hace tiempo que estoy tratando de sacar la siguiente consulta: en una tabla mysql tengo columnas con fechas, donde una fecha conocida, pero la otra puede estar en blanco. Lo que necesito es que cuando la fecha aparezca como Null la reemplace por la fecha actual para poder restar y calcular los días. He probado con todo y no resulta. sólo hace el cálculo de días si estan las dos fechas. Ojala alguien me pueda ayudar, muchas gracias.
  #2 (permalink)  
Antiguo 09/09/2008, 13:51
 
Fecha de Ingreso: julio-2007
Mensajes: 13
Antigüedad: 17 años, 4 meses
Puntos: 0
Respuesta: remplazar Null por Date()

intenta si lo quieres en php


if (!$fecha){
$fecha = date();
}

si no en javascript seria mas facil
  #3 (permalink)  
Antiguo 09/09/2008, 14:19
 
Fecha de Ingreso: septiembre-2008
Mensajes: 3
Antigüedad: 16 años, 2 meses
Puntos: 0
Respuesta: remplazar Null por Date()

gracias por la respuesta, pero ya estoy tan mareada que nada me resulta. envio la consulta.:

<?php

$sql="
SELECT registro_embarque.rut_tripulante,tripulante.nombre s,tripulante.apellidos,
registro_embarque.embarque, registro_embarque.desembarque, registro_embarque.desembarque_pro, cargos.descripcion, registro_embarque.id_embarque, registro_embarque.obs_embarque, registro_embarque.obs_desembarque, buque.nombre_buque,
datediff(desembarque, embarque) +1 as dias_embarque
FROM tripulante,buque,registro_embarque,cargos
WHERE
tripulante.rut_tripulante=registro_embarque.rut_tr ipulante
AND buque.cb=registro_embarque.cb
AND cargos.cod_cargo=tripulante.cod_cargo AND cargos.cod_cargo='$cod_cargo'
GROUP by id_embarque ORDER BY rut_tripulante,apellidos ASC


";

$result=mysql_query($sql);

}


if ($row= mysql_fetch_array($result))
{


echo '<table width="100%" border="0" cellspacing="1" bordercolor="#000000" bgcolor="#000000">
<tr bordercolor="#000000" bgcolor="#FFFFCC">';

echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>RUT</center></font></strong></td>';
echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>Nombre Completo</center></font></strong></td>';
echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>Cargo</center></font></strong></td>';
echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>Buque</center></font></strong></td>';
echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><strong><center>Fecha Embarque</center></strong></font></td>';
echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>Fecha Desembarque pro.</center></font></strong></td>';
echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>Fecha Desembarque</center></font></strong></td>';
echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>Dias Embarcado</center></font></strong></td>';
echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>Obser. Al Embarque</center></font></strong></td>';
echo '<td><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>Obser. Al Desembarque</center></font></strong></td>';



DO
{
echo '<tr bordercolor="#000000" bgcolor="#FFFFFF">';

echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"> <center> '.$row['rut_tripulante'].' </center></td>';

echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"> <center> '.$row['apellidos'].' '.$row['nombres'].' </center></td>';


echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"> <center> '.$row['descripcion'].' </center></td>';

echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"> <center> '.$row['nombre_buque'].' </center></td>';

echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>';
echo date('d/m/Y ',strtotime($row['embarque']));
echo '</center></td>';

echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>';
echo date('d/m/Y ',strtotime($row['desembarque_pro']));
echo '</center></td>';

echo '<td> <font color="#3333FF" size="1" face="Verdana, Arial, Helvetica, sans-serif"><center>';
echo ($row['desembarque']) ? date('d/m/Y',strtotime($row['desembarque'])) : 'Navegando';
echo '</center></td>';

//ES AQUI NO ME DA LOS DÍAS SI NO HAY FECHA DE DESEMBARQUE

echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"><font color="#FF0000"><center> '.$row['dias_embarque'].' </center></font></td>';


echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"> <center> '.$row['obs_embarque'].' </center></td>';
echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"> <center> '.$row['obs_desembarque'].' </center></td>';




}

WHILE ($row=mysql_fetch_array($result));

echo "</TABLE>";

}

else
{
echo '<font size="2" face="Verdana, Arial, Helvetica, sans-serif"><font color="#FF0000"><center>No Existe Registro de Embarques<center>';


}

?>
  #4 (permalink)  
Antiguo 09/09/2008, 15:10
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años, 5 meses
Puntos: 2135
Respuesta: remplazar Null por Date()

Puedes hacer algo así:
Código PHP:
echo '<td> <font size="1" face="Verdana, Arial, Helvetica, sans-serif"><font color="#FF0000"><center> '.(!empty( $row['dias_embarque']) ? $row['dias_embarque'] : '' ) .' </center></font></td>'
Saludos.
  #5 (permalink)  
Antiguo 09/09/2008, 17:05
 
Fecha de Ingreso: septiembre-2008
Mensajes: 3
Antigüedad: 16 años, 2 meses
Puntos: 0
Respuesta: remplazar Null por Date()

Hola nuevamente,

Creo que mi problema está en la consulta:

datediff(desembarque, embarque) +1 as dias_embarque

cuando el valor de registro es Null necesito que calcule los días trancurridos entre la fecha de embarque y la fecha de hoy y no se como hacer para que cualdo el valor sea null, tome el valor date (fecha de hoy) y lo asuma en la consulta y entonces en dias_embarque me muestre los dias que lleva navegando.


Gracias por la paciencia, En realidad el Foro es Excelente, he encontrado muchas soluciones. Ojalá me puedan ayudar
  #6 (permalink)  
Antiguo 09/09/2008, 19:27
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años, 5 meses
Puntos: 2135
Respuesta: remplazar Null por Date()

Hola sandrapola,

Puedes usar IF en tu sentencia MySQL, revisa el manual o pregunta en el foro de bases de datos, con el puedes checar si es nulo.

Saludos.
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 21:39.