Foros del Web » Programando para Internet » PHP »

select con varios where optativos

Estas en el tema de select con varios where optativos en el foro de PHP en Foros del Web. Hola. Estoy haciendo un programa para ver las rutas de distribución de la empresa. Hay 2 rutas (6 y 52) que trabajan los 6 días ...
  #1 (permalink)  
Antiguo 04/12/2015, 16:51
 
Fecha de Ingreso: julio-2006
Mensajes: 8
Antigüedad: 17 años, 8 meses
Puntos: 0
select con varios where optativos

Hola. Estoy haciendo un programa para ver las rutas de distribución de la empresa. Hay 2 rutas (6 y 52) que trabajan los 6 días de la semana (Lun, Mar, Mie,...).

Puse 2 listas/menú para seleccionar la ruta y el día. Pero yo quisiera que fuera ruta y día o ruta o día, dependiendo de lo que seleccionarran el las listas/menú.

Como lo tengo funciona bien si selecciono una ruta y un día. Pero si sólo selecciono una ruta o sólo selecciono un día, no me trae ningún registro.

Quisiera que si sólo se selecciona una ruta, mostrara todos los días de esa ruta
o si sólo se selecciona un día, mostrara todas las rutas de ese día
Cosas que podría cambiando el AND por un OR en las condiciones WHERE.
pero que si se seleccionan ruta y día, sólo mostrara los de esa ruta y ese día.
Aquí ya no funciona con OR, porque me traería todos los registros
de esa ruta y todos los registros de ese día.

Cómo acomodo los OR y AND para que funcione? o hay un valor comodin para asignarlo a la vaariable que no se use?

Les dejo el código que con el que estoy probando.

<?php require_once('../Connections/gramaorg_rp.php'); ?>
<?php
$NoReg = "0";
$colruta_rsclientes = "-1";
if (isset($_GET['ruta'])) {
$colruta_rsclientes = (get_magic_quotes_gpc()) ? $_GET['ruta'] : addslashes($_GET['ruta']);
}
$coldia_rsclientes = "-1";
if (isset($_GET['dia'])) {
$coldia_rsclientes = (get_magic_quotes_gpc()) ? $_GET['dia'] : addslashes($_GET['dia']);
}
mysql_select_db($database_gramaorg_rp, $gramaorg_rp);
$query_rsclientes = sprintf("SELECT ruta, id_cliente, nom_comercial, d_visita, latitud, longitud FROM cismar_clientes WHERE ruta = '%s' and d_visita = '%s' ORDER BY nom_comercial ASC", $colruta_rsclientes,$coldia_rsclientes);
$rsclientes = mysql_query($query_rsclientes, $gramaorg_rp) or die(mysql_error());
$row_rsclientes = mysql_fetch_assoc($rsclientes);
$totalRows_rsclientes = mysql_num_rows($rsclientes);
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Prueba</title>
</head>

<body>
<form name="form1" method="get" action="">
<table width="70%" border="0" align="center" cellpadding="5">
<tr>
<td> <label>Ruta
<select name="ruta" id="ruta" accesskey="r" tabindex="1">
<option value="-1" <?php if (!(strcmp(-1, $_GET['ruta']))) {echo "selected=\"selected\"";} ?>>Seleccionar</option>
<option value="6" <?php if (!(strcmp(6, $_GET['ruta']))) {echo "selected=\"selected\"";} ?>>Ruta 6</option>
<option value="52" <?php if (!(strcmp(52, $_GET['ruta']))) {echo "selected=\"selected\"";} ?>>Ruta 52</option>
</select>
</label>
</td>
<td><label>Día
<select name="dia" id="dia" accesskey="d" tabindex="2">
<option value="-1" <?php if (!(strcmp(-1, $_GET['dia']))) {echo "selected=\"selected\"";} ?>>Seleccionar</option>
<option value="LUN" <?php if (!(strcmp("LUN", $_GET['dia']))) {echo "selected=\"selected\"";} ?>>Lunes</option>
<option value="MAR" <?php if (!(strcmp("MAR", $_GET['dia']))) {echo "selected=\"selected\"";} ?>>Martes</option>
<option value="MIE" <?php if (!(strcmp("MIE", $_GET['dia']))) {echo "selected=\"selected\"";} ?>>Miércoles</option>
<option value="JUE" <?php if (!(strcmp("JUE", $_GET['dia']))) {echo "selected=\"selected\"";} ?>>Jueves</option>
<option value="VIE" <?php if (!(strcmp("VIE", $_GET['dia']))) {echo "selected=\"selected\"";} ?>>Viernes</option>
<option value="SAB" <?php if (!(strcmp("SAB", $_GET['dia']))) {echo "selected=\"selected\"";} ?>>Sábado</option>
</select>
</label>
</td>
<td><label>
<input type="submit" name="Submit" value="Buscar" accesskey="e" tabindex="9">
</label>
</td>
</tr>
</table>
</form>
<p>&nbsp;</p>
<p><a href="javascript:imprimir('map')"></a><BR />
<table width="70%" border="1" align="center" cellpadding="5">
<tr>
<td>REGISTRO</td>
<td>CLIENTE</td>
<td>RUTA</td>
<td>DÍA</td>
</tr>
<?php do { ?>
<?php $NoReg = $NoReg + "1"; ?>
<tr>
<td><?php echo $NoReg; ?></td>
<td><?php echo $row_rsclientes['id_cliente']; ?></td>
<td><?php echo $row_rsclientes['ruta']; ?></td>
<td><?php echo $row_rsclientes['d_visita']; ?></td>
</tr>
<?php } while ($row_rsclientes = mysql_fetch_assoc($rsclientes)); ?>
</table>
</body>
</html>
<?php
mysql_free_result($rsclientes);
?>

Etiquetas: mysql
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 02:02.