Foros del Web » Programando para Internet » PHP »

Select + mysql

Estas en el tema de Select + mysql en el foro de PHP en Foros del Web. Hola gente, miren tengo un sistema de noticias y para no complicarme la vida hice lo siguiente: Creo una base de datos con campos: id, ...
  #1 (permalink)  
Antiguo 01/09/2007, 23:19
 
Fecha de Ingreso: diciembre-2006
Mensajes: 294
Antigüedad: 17 años, 4 meses
Puntos: 2
Select + mysql

Hola gente, miren tengo un sistema de noticias y para no complicarme la vida hice lo siguiente:

Creo una base de datos con campos: id, titulo, fecha, noticia, imagen

En la pagina principal muestro las imagenes. Luego tengo un archivo para subir imagenes a un directorio determinado. Despues en otro archivo tengo para enviar las noticias, un muy simple formulario, donde pongo el titulo, la noticia y tengo un SELECT donde me muestra los nombres de las imagenes que agregué en la carpeta (sistema mencionado anteriormente).

El select es así:
Código PHP:
echo "<select name=imagen>";
$directorio opendir("img/");
while (
$imagen readdir($directorio))
{
    if (
$imagen != '.' && $imagen != '..' && strpos($imagen'.php') === false)
    {
        echo 
'<option value="' $imagen '">' $imagen '</option>';
    }    
}
closedir($directorio);
echo 
"
</select>"

Esto está todo OK, inserto la noticia, se inserta el titulo, la noticia y el nombre de la imagen en la BD. A al hora de mostrar la noticia es facil mostrar la imagen: <img src=$row[imagen]> y listo aparece la imagen

Pero mi problema es el siguiente: Tengo otro archivo que es para editar las noticias. Cuando elijo la noticia a edicar me rellena el formulario automaticamente mostrando que se ha ingresado en la noticia, es decir, en el input para el titulo aparece el titulo, en el textarea la noticia.... Pero quiero que me quede seleccionado en el SELECT la el nombre de imagen que ingresé. Por ejemplo tengo estas 4 imagen: 1.jpg, 2.jpg, 3.jpg y 4.jpg. Ingreso una noticia y selecciono la 3.jpg. A la hora de querer editar la noticia en el select no queda seleccionada la img 3.jpg sino la primera, que en este caso es la 1.jpg

Probé con <option select="select"> pero luego me di cuenta que era muy obvio, lo que pasaba es que todas estan seleccionadas :S:S:S

Me pueden ayudar ???

Gracias

Última edición por gesking; 01/09/2007 a las 23:29 Razón: Error
  #2 (permalink)  
Antiguo 02/09/2007, 11:27
 
Fecha de Ingreso: julio-2004
Mensajes: 117
Antigüedad: 19 años, 10 meses
Puntos: 0
Re: Select + mysql

Hola, si sabes de antemano, es decir, cuando cargas los valores del select, la imagen que corresponde, añades selected en su option.

Algo así como....
Código PHP:
$nombre_BD=imagen3.jpg //el nombre que saco de la base de datos

//Dentro de un bucle que rellena el select...

If ($nombre==$nombre_BD){
    echo  
"<option value='opcion2' selected>$nombre</option>";
}else{
    echo  
"<option value='opcion2' >$nombre</option>";

Es un ejemplo, tendrás que adaptarlo a tu código, pero la idea creo que es esa
Suerte
__________________
Uno para todos y todos para uno
  #3 (permalink)  
Antiguo 02/09/2007, 12:01
 
Fecha de Ingreso: diciembre-2006
Mensajes: 294
Antigüedad: 17 años, 4 meses
Puntos: 2
Re: Select + mysql

Hola, gracias por responderme.

Lo que pasa es que... no me funciona.... Hice lo siguiente y no pasa nada...

Mira esto es lo que hice:

Código PHP:
echo "<select name=\"imagen\">";
$directorio opendir("img/");
while (
$imagen readdir($directorio))
{
    if (
$imagen != '.' && $imagen != '..' && strpos($imagen'.php') === false)
    {
        echo 
'<option value="' $imagen '" selected="selected">' $imagen '</option>';
    } else {
        echo 
'<option value="' $imagen '">' $imagen '</option>';

}
closedir($directorio);
echo 
"</select>"
Desde ya gracias
  #4 (permalink)  
Antiguo 02/09/2007, 12:04
okram
Invitado
 
Mensajes: n/a
Puntos:
Re: Select + mysql

Que te parece esto?:

Código PHP:
$this_img $row['imagen'];
 
echo 
"<select name=imagen>\n";
$directorio opendir("img/");
while (
$imagen readdir($directorio))
{
    if (
$imagen != '.' && $imagen != '..' && strpos($imagen'.php') === false)
    {
        
$out "<option value=\"$imagen\"";
        
$out.= ($this_img == $imagen) ? " selected=\"selected\"" null;
        
$out ">$imagen</option>\n";
        echo 
$out;
    }    
}
closedir($directorio);
echo 
"</select>"
Un saludo,
  #5 (permalink)  
Antiguo 02/09/2007, 18:20
 
Fecha de Ingreso: diciembre-2006
Mensajes: 294
Antigüedad: 17 años, 4 meses
Puntos: 2
Re: Select + mysql

Gracias por tu colaboración okram, pero.... no me funciona, intenté modificarlo pero nada :S:S. Probé con lo que me diste pero directamente no me muestra las imagenes :S:S:S
  #6 (permalink)  
Antiguo 03/09/2007, 17:15
 
Fecha de Ingreso: diciembre-2006
Mensajes: 294
Antigüedad: 17 años, 4 meses
Puntos: 2
Re: Select + mysql

disculpen... pero... nadie me puede ayudar porfa??
  #7 (permalink)  
Antiguo 03/09/2007, 21:17
okram
Invitado
 
Mensajes: n/a
Puntos:
Re: Select + mysql

Código PHP:
$this_img $row['imagen']; //Esta es el nombre de la imagen, que sacas de la base de datos
 
echo "<select name=imagen>\n";
$directorio opendir("img/");
while (
false !== ($imagen readdir($directorio)))
{
    if (
$imagen != '.' && $imagen != '..' && strpos($imagen'.php') === false)
    {
        echo 
"<option value=\"$imagen\"";
        if(
$this_img == $imagen) echo " selected=\"selected\"";
        echo 
">$imagen</option>\n";
    }    
}
closedir($directorio);
echo 
"</select>"
$this_img guardara el nombre de la imagen que sacaste de la base de datos. Asi te deeria funcionar

Un saludo,
  #8 (permalink)  
Antiguo 04/09/2007, 15:22
 
Fecha de Ingreso: diciembre-2006
Mensajes: 294
Antigüedad: 17 años, 4 meses
Puntos: 2
Re: Select + mysql

Simple mi pregunta.... COMO LO HACES?? excelente, me quedó como yo necesitaba! te felicito por tu potencia ajajaja y muchas gracias man
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 23:01.