YII – Crear lista desplegable (Dropdown) desde BBDD

Si los datos los vas a obtener desde una tabla, lo correcto seria añadir en el modelo correspondiente esa funcionalidad.(si la lista la has de creara mano, sigue este comentario)

Supongamos que tengo una tabla de grupos de usuarios. La primera solución  seria como siempre resolver en el propio modelo de esta tabla algo como esto:

public function getGrupos($id=0)
{
$criteria=new CDbCriteria();
$criteria->select='id_grupo,Descripcion_Grupo'; //solo quiero estos dos campos
$criteria->order='ordenPresentacion'; //para que aparezcan clasificados
$criteria->addCondition('id_idioma=1'); //solo los que sean del idioma 1
if ($id>0)
$criteria->addCondition('id_grupo='.$id); //Si me indican id //busco  uno
$aGrupos=$this->findAll($criteria); //lanzo el query
$grupos=array();
foreach ($aGrupos as $p)
$grupos($p->id_grupo)= $p->Descripcion_Grupo; //monto array
return $grupos;
}

Con esto, conseguimos un array de  id-> descripción desde la tabla; la ventaja de este método es la precisión con la que podemos escoger y ordenar nuestra lista, en el formulario nos bastara con:

<?php echo $form->dropDownList($model,'id_grupo',$model->getGrupos()); ?>

Cuando no existan complicaciones de selección  podemos simplificar el sistema, modificando solo el form con estas lineas:

<?php echo $form->dropDownList($model,
'id_grupo',
CHtml::listData(CnArticuloGrupo::model()->findAll(), 'id_grupo', 'Descripcion_Grupo')
);?>

Bibliografia:

http://www.yiiframework.com/doc/api/1.1/CDbCriteria
http://yiitutorials.net/easy/yii-getting-info-from-the-database

Acerca de Miguel Garcia

Programador, Desarrollador web, Formador en distintas areas de informatica y director de equipos multidisciplinares.
Esta entrada fue publicada en Desarrollo Web, Formacion, YII - Generador de codigo PHP y etiquetada , , . Guarda el enlace permanente.

Una respuesta a YII – Crear lista desplegable (Dropdown) desde BBDD

  1. anubis dijo:

    gracias me sirvio tu ejemplo se agradece
    saludos

Deja un comentario

Este sitio usa Akismet para reducir el spam. Aprende cómo se procesan los datos de tus comentarios.