Foros del Web » Programando para Internet » PHP »

Problema PHP con mysql muestra numeros

Estas en el tema de Problema PHP con mysql muestra numeros en el foro de PHP en Foros del Web. Hola gente, Tengo un problema con un codigo, al cojer los datos de la tabla que tengo hecha en mysql, los coje perfectamente, pero al ...
  #1 (permalink)  
Antiguo 15/09/2010, 07:46
 
Fecha de Ingreso: septiembre-2010
Mensajes: 8
Antigüedad: 13 años, 7 meses
Puntos: 0
Problema PHP con mysql muestra numeros

Hola gente,

Tengo un problema con un codigo, al cojer los datos de la tabla que tengo hecha en mysql, los coje perfectamente, pero al pintarlo, me muestra el codigo, y no el nombre.

el codigo que tengo hecho, solamente ese trozo es este

Código:
<?php


/* Query Select tabla */ 
$query = mysql_query("SELECT * FROM ciudad"); 
while ($rec = mysql_fetch_array($query))
{ 
/* Opciones Selecion */ 
if ( $rec["codigo"] == 1 ) 
$opt = $opt."<option value=".$rec["codigo"]." selected>".$rec["nombre"]."</option>\n"; 
else 
$opt = $opt."<option value=".$rec["codigo"].">".$rec["nombre"]."</option>\n"; 
}  
echo <<< html
<form method="POST" action="contactar.php" name="ciudad"> 
<select size="1" name="ciudad" tabindex="1">$opt</select><br><br> 
</form> 
html;

?>
  #2 (permalink)  
Antiguo 15/09/2010, 08:00
Avatar de Vun
Vun
Colaborador
 
Fecha de Ingreso: agosto-2009
Ubicación: Benalmádena, España
Mensajes: 2.265
Antigüedad: 14 años, 8 meses
Puntos: 150
Respuesta: Problema PHP con mysql muestra numeros

¿de que campos se compone la tabla ciudad? Prueba a poner $rec[0] en vez de $rec["nombre"] siendo 0 la primera columna, 1 la segunda columna y asi...
  #3 (permalink)  
Antiguo 15/09/2010, 08:10
 
Fecha de Ingreso: septiembre-2010
Mensajes: 8
Antigüedad: 13 años, 7 meses
Puntos: 0
Respuesta: Problema PHP con mysql muestra numeros

Ahora lo tengo asi, pero al escojer la ciudad desde la web, me envia un correo, y donde poner Ciudad: no me da la ciudad, me da un 1 o el numero que este de la ciudad en la base de datos, no se si me explico muy bien... :S

Código:
<?php


/* Query Select tabla */ 
$query = mysql_query("SELECT * FROM ciudad"); 
while ($rec = mysql_fetch_array($query))
{ 
/* Opciones Selecion */ 
if ( $rec["codigo"] == 1 ) 
$opt = $opt."<option value=".$rec["codigo"]." selected>".$rec[0]."</option>\n"; 
else 
$opt = $opt."<option value=".$rec["codigo"].">".$rec[0]."</option>\n"; 
}  
echo <<< html
<form method="POST" action="contactar.php" name="ciudad"> 
<select size="1" name="ciudad" tabindex="1">$opt</select><br><br> 
</form> 
html;

?>
  #4 (permalink)  
Antiguo 15/09/2010, 08:36
Avatar de Vun
Vun
Colaborador
 
Fecha de Ingreso: agosto-2009
Ubicación: Benalmádena, España
Mensajes: 2.265
Antigüedad: 14 años, 8 meses
Puntos: 150
Respuesta: Problema PHP con mysql muestra numeros

Te pediría que me pusieras los datos que te pedí, antes de confundirme con eso de que se envia un email...
  #5 (permalink)  
Antiguo 15/09/2010, 08:36
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Tema movido desde Configuración PHP a PHP
  #6 (permalink)  
Antiguo 15/09/2010, 10:35
 
Fecha de Ingreso: septiembre-2010
Mensajes: 8
Antigüedad: 13 años, 7 meses
Puntos: 0
Respuesta: Problema PHP con mysql muestra numeros

Te dejo el SQL


Código:
CREATE TABLE ciudad ( 
codigo int(2) NOT NULL auto_increment, 
nombre varchar(30) NOT NULL default '', 
PRIMARY KEY (codigo) 
) TYPE=MyISAM; 

INSERT INTO ciudad VALUES (1, 'Mataro'); 
INSERT INTO ciudad VALUES (2, 'Argentona'); 
INSERT INTO ciudad VALUES (3, 'Cabrera'); 
INSERT INTO ciudad VALUES (4, 'Vilasar de Mar'); 
INSERT INTO ciudad VALUES (5, 'Vilasar de Dalt'); 
INSERT INTO ciudad VALUES (6, 'Masnou'); 
INSERT INTO ciudad VALUES (7, 'Alella'); 
INSERT INTO ciudad VALUES (8, 'Prueva'); 
INSERT INTO ciudad VALUES (9, 'Maresme');
  #7 (permalink)  
Antiguo 15/09/2010, 10:51
Avatar de Vun
Vun
Colaborador
 
Fecha de Ingreso: agosto-2009
Ubicación: Benalmádena, España
Mensajes: 2.265
Antigüedad: 14 años, 8 meses
Puntos: 150
Respuesta: Problema PHP con mysql muestra numeros

Pues debería aparecer el nombre de la ciudad con $rec["nombre"] como tenias al inicio o $rec[1].

mmmmmm, por cambiar algo, prueba asi:

Código PHP:
<?php
/* Query Select tabla */ 
$query mysql_query("SELECT * FROM ciudad"); 
while (
$rec mysql_fetch_array($query))

/* Opciones Selecion */ 
if ( $rec["codigo"] == 
$opt $opt."<option value=".$rec["codigo"]." selected>".$rec[1]."</option>\n"
else 
$opt $opt."<option value=".$rec["codigo"].">".$rec[1]."</option>\n"
}  
?>
<form method="POST" action="contactar.php" name="ciudad"> 
<select size="1" name="ciudad" tabindex="1"><?=$opt?></select><br><br> 
</form>
Si no funciona, prueba esto:

Código PHP:
$query mysql_query("SELECT * FROM ciudad"); 
while (
$rec mysql_fetch_array($query)) { 
    echo 
$rec[0]." - ".$rec[1]." - <br>";

Y pon aqui lo que sale
  #8 (permalink)  
Antiguo 15/09/2010, 10:59
 
Fecha de Ingreso: septiembre-2010
Mensajes: 8
Antigüedad: 13 años, 7 meses
Puntos: 0
Respuesta: Problema PHP con mysql muestra numeros

No funciona ninguna de las 2 cosas, el de arriba, me sale igual numeros, y cambiando lo que me as puesto abajo, me sale fuera del select, se ven todas las ciudades, pero no me deja elejir
  #9 (permalink)  
Antiguo 15/09/2010, 11:02
 
Fecha de Ingreso: septiembre-2010
Mensajes: 8
Antigüedad: 13 años, 7 meses
Puntos: 0
Respuesta: Problema PHP con mysql muestra numeros

Ya lo e podido Solucionar, lo e dejado Asi

if ( $rec["codigo"] == 1 )
$opt = $opt."<option value=".$rec[1]." selected>".$rec["nombre"]."</option>\n";
else
$opt = $opt."<option value=".$rec[1].">".$rec["nombre"]."</option>\n";
}

Muchas gracias por Ayudarme
  #10 (permalink)  
Antiguo 15/09/2010, 12:05
Avatar de Vun
Vun
Colaborador
 
Fecha de Ingreso: agosto-2009
Ubicación: Benalmádena, España
Mensajes: 2.265
Antigüedad: 14 años, 8 meses
Puntos: 150
Respuesta: Problema PHP con mysql muestra numeros

Ah, que era lo del value lo que estaba mal, si es que mi compresión lectora no esta hoy muy.........
  #11 (permalink)  
Antiguo 15/09/2010, 14:10
 
Fecha de Ingreso: febrero-2010
Mensajes: 818
Antigüedad: 14 años, 2 meses
Puntos: 55
Respuesta: Problema PHP con mysql muestra numeros

cambia el mysql_fetch_array por mysql_fetch_assoc y deberia funcionar

Etiquetas: muestra, mysql, numeros
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 08:16.