Datacombo para Visual C++

Por:ivancp,enviado 14 Mar 2004
Éste es un control basado en un cuadro combinado, usa una conexion existente de tipo CDaoDatabase. Puede servirte en tus aplicaciones en donde ya tengas una conexión de ése tipo. En la imagen siguiente se puede ver en accion al control, donde recupera registros de una tabla "Paises" y el otro control de la tabla "Departamentos".

datacombo.gif
Datacombo en acción en un formulario Visual C++


Asignamos esta conexión mediante la función creada SetConnection.

Code: Seleccionar todo
  1. void CDatacombo::SetConnection(CDaoDatabase *pDB)

  2. {

  3.   m_pDB = pDB;

  4. }



La funcion LoadData recupera los datos segun la consulta SQL que se le envíe, pero esta consulta debe retornar un conjunto de registros de manera que el primer campo sea numérico y el segundo de tipo cadena, el primero es asigando mediante la función CComboBox::SetItemData(), es segundo es asginado como item del control para que se pueda ver.

Code: Seleccionar todo
  1. void CDatacombo::LoadData()

  2. {

  3.   ASSERT(::IsWindow(m_hWnd));

  4.   ASSERT(m_pDB);

  5.   ASSERT(m_pDB->IsOpen());

  6.   ASSERT(!m_sSQL.IsEmpty());

  7.  

  8.  

  9.   CDaoRecordset rs(m_pDB);

  10.   COleVariant var;

  11.  

  12.   try{

  13.     rs.Open(dbOpenSnapshot,m_sSQL);  

  14.     INT i = 0;

  15.     ResetContent();

  16.     while(!rs.IsEOF()){

  17.       rs.GetFieldValue(1,var);

  18.       InsertString(i,CCrack::strVARIANT(var));

  19.  

  20.       rs.GetFieldValue(0,var);

  21.       switch(var.vt){

  22.         case VT_I2:

  23.           SetItemData(i,(DWORD)V_I2(&var));

  24.           break;

  25.         case VT_I4:

  26.           SetItemData(i,(DWORD)V_I4(&var));

  27.           break;

  28.         case VT_R4:

  29.           SetItemData(i,(DWORD)V_R4(&var));

  30.           break;

  31.         case VT_R8:

  32.           SetItemData(i,(DWORD)V_R8(&var));

  33.           break;

  34.       }

  35.       i++;

  36.       rs.MoveNext();

  37.     }

  38.  

  39.   }catch(CDaoException e){

  40.  

  41.   }catch(CMemoryException e){

  42.  

  43.   }

  44.  

  45.   if(rs.IsOpen()){

  46.     rs.Close();

  47.   }

  48. }

Archivos Adjuntos

Otros Artículos en esta sección

  • Calculadora en Visual C++
    Es un tutorial sobre como implementar una calculadora científica desde cero con Visual C++ con MFC. También se implementa el calculo de algunas funciones matemáticas.
    Por: ivancp,2008-05-03
  • Utilizar números decimales en Visual C++
    Un control para el manejo de números decimales en Visual C++, está basado en la clase CEdit, y ha sido modificada para poder manipular y visualizar números decimales en formularios MFC.
    Por: ivancp,2008-05-11
  • Crear un proyecto MFC basado en diálogo
    Tutorial paso a paso para crear una aplicación basada en dialogo utilizando las librerías MFC con Visual C++ 2010
    Por: ivancp,2011-09-03
¿Alguna duda? Sientete libre de hacer tus pruntas en nuestro:
foro deVisual C++ »