Foros del Web » Programando para Internet » PHP »

Problemas con combobox

Estas en el tema de Problemas con combobox en el foro de PHP en Foros del Web. Hola. Tengo el sigte codigo; echo"<tr>"; echo"<td><b>Ciudad</b>"; //************************************************** ************************************************** ************ $sql1 = "SELECT * FROM CIUDAD__CIUD"; $res = mysql_query($sql1) or die("La consulta fall&oacute;: " . ...
  #1 (permalink)  
Antiguo 15/07/2008, 17:26
 
Fecha de Ingreso: marzo-2005
Mensajes: 156
Antigüedad: 19 años, 1 mes
Puntos: 0
Problemas con combobox

Hola.
Tengo el sigte codigo;
echo"<tr>";
echo"<td><b>Ciudad</b>";
//************************************************** ************************************************** ************
$sql1 = "SELECT * FROM CIUDAD__CIUD";
$res = mysql_query($sql1) or die("La consulta fall&oacute;: " . mysql_error());
$num=mysql_numrows($res);
//echo"$num";
echo"<td >\n";
echo"<select name='ciudad' id='ciudad'>\n";
echo "<option value=''>$txtciudad</option>";
for ($i=0; $i<$num; $i++)
{
$CIUD_CODIGO=mysql_result($res,$i,"CIUD_CODIGO");
$CIUD_NOMBRE=mysql_result($res,$i,"CIUD_NOMBRE");
echo "<option value=$CIUD_CODIGO>$CIUD_NOMBRE</option>";
}
echo"</select></td>\n";
echo"</tr>\n";

Con esto deberia cargar el combobox con el nombre de la ciudad, pero esa ciudad deberia ser unica. Me explico.
en el combobox cuando yo ejecuto la pagina aparece:
ciudad: chillan
santiago
chillan
lima
mendoza

pero la idea es que no se repitan campos. Por lo que deberia quedar de la siguiente manera:

ciudad : chillan
santiago
lima
mendoza

por favor agradesco su ayudas.
gracias
  #2 (permalink)  
Antiguo 15/07/2008, 18:07
 
Fecha de Ingreso: junio-2008
Mensajes: 31
Antigüedad: 15 años, 11 meses
Puntos: 0
Respuesta: Problemas con combobox

hola cearriag, podrias solucionar tu problema modificando un poco tu sentencia sql

agrega el Valor GROUP BY en tu sentencia sql,

SELECT * FROM `CIUDAD__CIUD` GROUP BY CIUD_NOMBRE


fijate si te funciona y corregime si estoy equivocado.


PD: igual es medio raro lo que estas haciendo, digo por la forma que utilizas para mostrar el resultado del php con echo. Aunque no conosco la totalidad del codigo.
  #3 (permalink)  
Antiguo 15/07/2008, 18:17
 
Fecha de Ingreso: marzo-2005
Mensajes: 156
Antigüedad: 19 años, 1 mes
Puntos: 0
Respuesta: Problemas con combobox

Esta opciòn me funca mas, pero cuando selecciono otra alternativa para updatear el registro no mo envia..
El registro que deseo enviar es por el parametro "ciudad". te dejo parte del codigo.
$sql = "SELECT * FROM ciudad__CIUD";
$res = mysql_query($sql) or die("La consulta fall&oacute;: " . mysql_error());
$num=mysql_num_rows($res);

echo"<td width='33%'><b>Ciudad</b></td>\n";
echo"<td width='34%' align='left'>";
//aqui deveria mostrar el nombre de la ocupacion que tenia antes el combo y mostrarlo en pantalla
echo"<select name='ciudad' size='1' id='ciudad'>\n";
while ($row=mysql_fetch_array($res))
{
if($ocupacion == $row['ciud_codigo'])
{
$selected = 'selected="selected"';
}

echo "<option value=\"".$row['ciud_codigo']."\" ".$selected.">".$row['CIUD_NOMBRE']."</option>\n";
}
echo"</select>\n";

El error es el siguiente:









UPDATE profesor__prof SET profesor__prof.CIUD_CODIGO=, profesor__prof.PROF_NOMBRE='h', profesor__prof.PROF_APELLIDO_PATERNO='a', profesor__prof.PROF_APELLIDO_MATERNO='a', profesor__prof.PROF_EDAD=77, profesor__prof.PROF_DIRECCION='aa', profesor__prof.PROF_TELEFONO='88', profesor__prof.PROF_TELEFONO_MOVIL=88, profesor__prof.PROF_EMAIL='aaa', profesor__prof.PROF_CANT_HORAS=87, profesor__prof.PROF_ESPECIALIDAD='aaa' WHERE profesor__prof.PROF_RUT='15195538-k'

ahì se indica que el profesor__prof.ciud_codigo no me esta updateando.
desconozco el error.
gracias
  #4 (permalink)  
Antiguo 16/07/2008, 15:58
 
Fecha de Ingreso: junio-2008
Mensajes: 31
Antigüedad: 15 años, 11 meses
Puntos: 0
Respuesta: Problemas con combobox

cearrig, tengo pocos datos, pero me parece que lo que esta ocurriendo es que el dato que viene del select ( en este caso llamado 'ciudad' ) no esta bien tomado.

Para tomar el dato del select luego del envio del formulario por parte de algun usuario tendrias que utilizar $_POST['ciudad'] o $_GET['ciudad'], dependiendo del method del form en el que esta el select( supongo que esta dentro de algun form ¿no? ).


Te podes fijar si los datos estan llegando a php introduciendo el siguiente codigo:

Código PHP:
print_r($_POST); 
o
Código PHP:
print_r($_GET); 
otra cosa:
ojo que estas llamando a CIUD_CODIGO a veces con minuscula y a veces con mayuscula, tene cuidado con eso pq puede que en windows funcione bien siempre, pero si tenes un servidor linux en muchas cosas CIUD_CODIGO seria distinto a ciud_codigo
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 12:05.