Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • World
  • Users
  • Groups
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Code Project
  1. Home
  2. General Programming
  3. C / C++ / MFC
  4. MFC VC++ Repopulating the ClistCtrl after database is updated through dialog

MFC VC++ Repopulating the ClistCtrl after database is updated through dialog

Scheduled Pinned Locked Moved C / C++ / MFC
c++helpdatabasedebuggingannouncement
18 Posts 4 Posters 0 Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • L Lost User

    We cannot help without seeing the code and the error details.

    M Offline
    M Offline
    Member_14575556
    wrote on last edited by
    #3

    Below are my codes. I'm new to MFC VC++ and in learning process, pls excuse my coding standard. This is the Error I got: Exception thrown at 0x00007FFCFBE90CC3 (mfc140ud.dll) in Medication_Administration.exe: 0xC0000005: Access violation reading location 0x0000000000000040. If there is a handler for this exception, the program may be safely continued. 1st Dialog :

    // Medication_AdministrationDlg.cpp : implementation file
    //

    #include "stdafx.h"
    #include "Medication_Administration.h"
    #include "Medication_AdministrationDlg.h"
    #include "afxdialogex.h"
    #include "odbcinst.h"
    #include "afxdb.h"
    #include "MedicineDlg.h"

    #ifdef _DEBUG
    #define new DEBUG_NEW
    #endif

    // CPatientDlg dialog

    CPatientDlg::CPatientDlg(CWnd* pParent /*=NULL*/)
    : CDialogEx(IDD_MEDICATION_ADMINISTRATION_DIALOG, pParent)
    , m_strSearch(_T(""))
    {
    m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
    }

    void CPatientDlg::DoDataExchange(CDataExchange* pDX)
    {
    CDialogEx::DoDataExchange(pDX);
    DDX_Control(pDX, IDC_PATIENT_LIST, m_ListControl);
    DDX_Text(pDX, IDC_SEARCH_BOX, m_strSearch);
    }

    BEGIN_MESSAGE_MAP(CPatientDlg, CDialogEx)
    ON_WM_SYSCOMMAND()
    ON_WM_PAINT()
    ON_WM_QUERYDRAGICON()
    ON_BN_CLICKED(IDC_SEARCH_BUTTON, &CPatientDlg::OnBnClickedSearchButton)
    ON_BN_CLICKED(IDC_SELECT_BUTTON, &CPatientDlg::OnBnClickedSelectButton)
    END_MESSAGE_MAP()

    // CPatientDlg message handlers

    BOOL CPatientDlg::OnInitDialog()
    {
    CDialogEx::OnInitDialog();

    // Set the icon for this dialog.  The framework does this automatically
    //  when the application's main window is not a dialog
    SetIcon(m\_hIcon, TRUE);			// Set big icon
    SetIcon(m\_hIcon, FALSE);		// Set small icon
    
    ShowWindow(SW\_MINIMIZE);
    
    // TODO: Add extra initialization here
    m\_strSearch = "Enter name or MRN to search";
    UpdateData(FALSE);
    
    return TRUE;  // return TRUE  unless you set the focus to a control
    

    }

    void CPatientDlg::OnSysCommand(UINT nID, LPARAM lParam)
    {

    	CDialogEx::OnSysCommand(nID, lParam);
    

    }

    // If you add a minimize button to your dialog, you will need the code below
    // to draw the icon. For MFC applications using the document/view model,
    // this is automatically done for you by the framework.

    void CPatientDlg::OnPaint()
    {
    if (IsIconic())
    {
    CPaintDC dc(this); // device context for painting

    	SendMessage(WM\_ICONERASEBKGND, reinterpret\_cast(dc.GetSafeHdc()), 0);
    
    	// Center icon in client rectangle
    	int cxIcon = GetSystemMetrics(SM\_CXICON);
    
    L D 2 Replies Last reply
    0
    • M Member_14575556

      Below are my codes. I'm new to MFC VC++ and in learning process, pls excuse my coding standard. This is the Error I got: Exception thrown at 0x00007FFCFBE90CC3 (mfc140ud.dll) in Medication_Administration.exe: 0xC0000005: Access violation reading location 0x0000000000000040. If there is a handler for this exception, the program may be safely continued. 1st Dialog :

      // Medication_AdministrationDlg.cpp : implementation file
      //

      #include "stdafx.h"
      #include "Medication_Administration.h"
      #include "Medication_AdministrationDlg.h"
      #include "afxdialogex.h"
      #include "odbcinst.h"
      #include "afxdb.h"
      #include "MedicineDlg.h"

      #ifdef _DEBUG
      #define new DEBUG_NEW
      #endif

      // CPatientDlg dialog

      CPatientDlg::CPatientDlg(CWnd* pParent /*=NULL*/)
      : CDialogEx(IDD_MEDICATION_ADMINISTRATION_DIALOG, pParent)
      , m_strSearch(_T(""))
      {
      m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
      }

      void CPatientDlg::DoDataExchange(CDataExchange* pDX)
      {
      CDialogEx::DoDataExchange(pDX);
      DDX_Control(pDX, IDC_PATIENT_LIST, m_ListControl);
      DDX_Text(pDX, IDC_SEARCH_BOX, m_strSearch);
      }

      BEGIN_MESSAGE_MAP(CPatientDlg, CDialogEx)
      ON_WM_SYSCOMMAND()
      ON_WM_PAINT()
      ON_WM_QUERYDRAGICON()
      ON_BN_CLICKED(IDC_SEARCH_BUTTON, &CPatientDlg::OnBnClickedSearchButton)
      ON_BN_CLICKED(IDC_SELECT_BUTTON, &CPatientDlg::OnBnClickedSelectButton)
      END_MESSAGE_MAP()

      // CPatientDlg message handlers

      BOOL CPatientDlg::OnInitDialog()
      {
      CDialogEx::OnInitDialog();

      // Set the icon for this dialog.  The framework does this automatically
      //  when the application's main window is not a dialog
      SetIcon(m\_hIcon, TRUE);			// Set big icon
      SetIcon(m\_hIcon, FALSE);		// Set small icon
      
      ShowWindow(SW\_MINIMIZE);
      
      // TODO: Add extra initialization here
      m\_strSearch = "Enter name or MRN to search";
      UpdateData(FALSE);
      
      return TRUE;  // return TRUE  unless you set the focus to a control
      

      }

      void CPatientDlg::OnSysCommand(UINT nID, LPARAM lParam)
      {

      	CDialogEx::OnSysCommand(nID, lParam);
      

      }

      // If you add a minimize button to your dialog, you will need the code below
      // to draw the icon. For MFC applications using the document/view model,
      // this is automatically done for you by the framework.

      void CPatientDlg::OnPaint()
      {
      if (IsIconic())
      {
      CPaintDC dc(this); // device context for painting

      	SendMessage(WM\_ICONERASEBKGND, reinterpret\_cast(dc.GetSafeHdc()), 0);
      
      	// Center icon in client rectangle
      	int cxIcon = GetSystemMetrics(SM\_CXICON);
      
      L Offline
      L Offline
      Lost User
      wrote on last edited by
      #4

      You need to show us where the exception was thrown. Use the debugger to run the program and check the stack windo when the exception occurs.

      M 1 Reply Last reply
      0
      • L Lost User

        You need to show us where the exception was thrown. Use the debugger to run the program and check the stack windo when the exception occurs.

        M Offline
        M Offline
        Member_14575556
        wrote on last edited by
        #5

        Thanks for replying. It when the below function is called.. I've marked the exact line.

        void MedicationDlg::OnBnClickedSaveButtonMedicationDlg(){
        ..........
        ..........
        MedicineObj.ResetListControl(); /* <-----when this function was called exception was thrown*/
        MedicineObj.DatabaseReload();
        OnOK();

        }

        This functions is in 2nd dialog:

        void MedicineDlg::ResetListControl() {
        m_MedListControl.DeleteAllItems(); /* <----- This is the exact line when execute exceptions was thrown*/
        int nColumnCount = m_MedListControl.GetHeaderCtrl()->GetItemCount();

        // Delete all of the columns.
        for (int i = 0; i < nColumnCount; i++)
        {
        	m\_MedListControl.DeleteColumn(0);
        }
        

        }

        D V 2 Replies Last reply
        0
        • M Member_14575556

          Thanks for replying. It when the below function is called.. I've marked the exact line.

          void MedicationDlg::OnBnClickedSaveButtonMedicationDlg(){
          ..........
          ..........
          MedicineObj.ResetListControl(); /* <-----when this function was called exception was thrown*/
          MedicineObj.DatabaseReload();
          OnOK();

          }

          This functions is in 2nd dialog:

          void MedicineDlg::ResetListControl() {
          m_MedListControl.DeleteAllItems(); /* <----- This is the exact line when execute exceptions was thrown*/
          int nColumnCount = m_MedListControl.GetHeaderCtrl()->GetItemCount();

          // Delete all of the columns.
          for (int i = 0; i < nColumnCount; i++)
          {
          	m\_MedListControl.DeleteColumn(0);
          }
          

          }

          D Offline
          D Offline
          David Crow
          wrote on last edited by
          #6

          Does m_MedListControl have a non-null value?

          "One man's wage rise is another man's price increase." - Harold Wilson

          "Fireproof doesn't mean the fire will never come. It means when the fire comes that you will be able to withstand it." - Michael Simmons

          "You can easily judge the character of a man by how he treats those who can do nothing for him." - James D. Miles

          M 1 Reply Last reply
          0
          • D David Crow

            Does m_MedListControl have a non-null value?

            "One man's wage rise is another man's price increase." - Harold Wilson

            "Fireproof doesn't mean the fire will never come. It means when the fire comes that you will be able to withstand it." - Michael Simmons

            "You can easily judge the character of a man by how he treats those who can do nothing for him." - James D. Miles

            M Offline
            M Offline
            Member_14575556
            wrote on last edited by
            #7

            Yes, what I did was in the 2nd dialog there will be a list view control already populated with the database data when a button is clicked in the 1st dialog. when I click one of the row in the 2nd dialog list view control, 3rd dialog will pop up where I'll enter some data which will be updated to the database and then I delete all the items in the 2nd dialog list view controlled and tries to repopulate again with the updated data in the database.

            L 1 Reply Last reply
            0
            • M Member_14575556

              Yes, what I did was in the 2nd dialog there will be a list view control already populated with the database data when a button is clicked in the 1st dialog. when I click one of the row in the 2nd dialog list view control, 3rd dialog will pop up where I'll enter some data which will be updated to the database and then I delete all the items in the 2nd dialog list view controlled and tries to repopulate again with the updated data in the database.

              L Offline
              L Offline
              Lost User
              wrote on last edited by
              #8

              No, that is what you think will happen. The only way to be certain is by using the debugger to check exactly what bad address is causing the exception. And no one hare can do that for you.

              M 1 Reply Last reply
              0
              • M Member_14575556

                Thanks for replying. It when the below function is called.. I've marked the exact line.

                void MedicationDlg::OnBnClickedSaveButtonMedicationDlg(){
                ..........
                ..........
                MedicineObj.ResetListControl(); /* <-----when this function was called exception was thrown*/
                MedicineObj.DatabaseReload();
                OnOK();

                }

                This functions is in 2nd dialog:

                void MedicineDlg::ResetListControl() {
                m_MedListControl.DeleteAllItems(); /* <----- This is the exact line when execute exceptions was thrown*/
                int nColumnCount = m_MedListControl.GetHeaderCtrl()->GetItemCount();

                // Delete all of the columns.
                for (int i = 0; i < nColumnCount; i++)
                {
                	m\_MedListControl.DeleteColumn(0);
                }
                

                }

                V Offline
                V Offline
                Victor Nijegorodov
                wrote on last edited by
                #9

                Member 14575556 wrote:

                void MedicationDlg::OnBnClickedSaveButtonMedicationDlg(){ .......... .......... MedicineObj.ResetListControl(); /* <-----when this function was called exception was thrown*/ MedicineObj.DatabaseReload(); OnOK(); }

                What is this MedicineObj? Where and how is it defined?

                M 1 Reply Last reply
                0
                • V Victor Nijegorodov

                  Member 14575556 wrote:

                  void MedicationDlg::OnBnClickedSaveButtonMedicationDlg(){ .......... .......... MedicineObj.ResetListControl(); /* <-----when this function was called exception was thrown*/ MedicineObj.DatabaseReload(); OnOK(); }

                  What is this MedicineObj? Where and how is it defined?

                  M Offline
                  M Offline
                  Member_14575556
                  wrote on last edited by
                  #10

                  MedicineDlg MedicineObj;

                  It is an object for MedicineDlg.

                  void MedicationDlg::OnBnClickedSaveButtonMedicationDlg()
                  {
                  // TODO: Add your control notification handler code here
                  CString m_MedStatusInput, m_MedCommentInput, m_MedDoseInput, m_MedRouteInput, SqlQuery;
                  m_MedDose_MedicationDlg.GetLBText(m_MedDose_MedicationDlg.GetCurSel(), m_MedDoseInput);
                  m_MedRoute_MedicationDlg.GetLBText(m_MedRoute_MedicationDlg.GetCurSel(), m_MedRouteInput);
                  UpdateData(TRUE);
                  m_MedStatusInput = m_MedStatus_MedicationDlg;
                  m_MedCommentInput = m_MedComments_MedicationDlg;

                  CDatabase dbobj;
                  dbobj.OpenEx(\_T("DSN=Demo;UID=root;PWD=root"));
                  CRecordset recset(&dbobj);
                  SqlQuery.Format(\_T("UPDATE dbdemo.medicine SET Route = '%s', Dose = '%s',Status = '%s',Comment = '%s' WHERE NDC ='%s'"), m\_MedRouteInput, m\_MedDoseInput, m\_MedStatusInput, m\_MedCommentInput, m\_MedDSNInput);
                  dbobj.ExecuteSQL(SqlQuery);//till here its working
                  MedicineDlg MedicineObj;
                  MedicineObj.ResetListControl();// Here the code breaks
                  MedicineObj.DatabaseReload();
                  
                  OnOK();
                  

                  }

                  V 1 Reply Last reply
                  0
                  • L Lost User

                    No, that is what you think will happen. The only way to be certain is by using the debugger to check exactly what bad address is causing the exception. And no one hare can do that for you.

                    M Offline
                    M Offline
                    Member_14575556
                    wrote on last edited by
                    #11

                    Yes I did that and still I couldn't fix it... Thanks anyway. I'll try harder.

                    1 Reply Last reply
                    0
                    • M Member_14575556

                      MedicineDlg MedicineObj;

                      It is an object for MedicineDlg.

                      void MedicationDlg::OnBnClickedSaveButtonMedicationDlg()
                      {
                      // TODO: Add your control notification handler code here
                      CString m_MedStatusInput, m_MedCommentInput, m_MedDoseInput, m_MedRouteInput, SqlQuery;
                      m_MedDose_MedicationDlg.GetLBText(m_MedDose_MedicationDlg.GetCurSel(), m_MedDoseInput);
                      m_MedRoute_MedicationDlg.GetLBText(m_MedRoute_MedicationDlg.GetCurSel(), m_MedRouteInput);
                      UpdateData(TRUE);
                      m_MedStatusInput = m_MedStatus_MedicationDlg;
                      m_MedCommentInput = m_MedComments_MedicationDlg;

                      CDatabase dbobj;
                      dbobj.OpenEx(\_T("DSN=Demo;UID=root;PWD=root"));
                      CRecordset recset(&dbobj);
                      SqlQuery.Format(\_T("UPDATE dbdemo.medicine SET Route = '%s', Dose = '%s',Status = '%s',Comment = '%s' WHERE NDC ='%s'"), m\_MedRouteInput, m\_MedDoseInput, m\_MedStatusInput, m\_MedCommentInput, m\_MedDSNInput);
                      dbobj.ExecuteSQL(SqlQuery);//till here its working
                      MedicineDlg MedicineObj;
                      MedicineObj.ResetListControl();// Here the code breaks
                      MedicineObj.DatabaseReload();
                      
                      OnOK();
                      

                      }

                      V Offline
                      V Offline
                      Victor Nijegorodov
                      wrote on last edited by
                      #12

                      Member 14575556 wrote:

                      MedicineDlg MedicineObj; MedicineObj.ResetListControl();// Here the code breaks

                      It is some "empty", i.e. not created/initialized object that has nothing to do with a really displayed dialog!

                      M 1 Reply Last reply
                      0
                      • V Victor Nijegorodov

                        Member 14575556 wrote:

                        MedicineDlg MedicineObj; MedicineObj.ResetListControl();// Here the code breaks

                        It is some "empty", i.e. not created/initialized object that has nothing to do with a really displayed dialog!

                        M Offline
                        M Offline
                        Member_14575556
                        wrote on last edited by
                        #13

                        I have included the header file of MedicineDlg (MedicineDlg.h)

                        V 1 Reply Last reply
                        0
                        • M Member_14575556

                          Below are my codes. I'm new to MFC VC++ and in learning process, pls excuse my coding standard. This is the Error I got: Exception thrown at 0x00007FFCFBE90CC3 (mfc140ud.dll) in Medication_Administration.exe: 0xC0000005: Access violation reading location 0x0000000000000040. If there is a handler for this exception, the program may be safely continued. 1st Dialog :

                          // Medication_AdministrationDlg.cpp : implementation file
                          //

                          #include "stdafx.h"
                          #include "Medication_Administration.h"
                          #include "Medication_AdministrationDlg.h"
                          #include "afxdialogex.h"
                          #include "odbcinst.h"
                          #include "afxdb.h"
                          #include "MedicineDlg.h"

                          #ifdef _DEBUG
                          #define new DEBUG_NEW
                          #endif

                          // CPatientDlg dialog

                          CPatientDlg::CPatientDlg(CWnd* pParent /*=NULL*/)
                          : CDialogEx(IDD_MEDICATION_ADMINISTRATION_DIALOG, pParent)
                          , m_strSearch(_T(""))
                          {
                          m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
                          }

                          void CPatientDlg::DoDataExchange(CDataExchange* pDX)
                          {
                          CDialogEx::DoDataExchange(pDX);
                          DDX_Control(pDX, IDC_PATIENT_LIST, m_ListControl);
                          DDX_Text(pDX, IDC_SEARCH_BOX, m_strSearch);
                          }

                          BEGIN_MESSAGE_MAP(CPatientDlg, CDialogEx)
                          ON_WM_SYSCOMMAND()
                          ON_WM_PAINT()
                          ON_WM_QUERYDRAGICON()
                          ON_BN_CLICKED(IDC_SEARCH_BUTTON, &CPatientDlg::OnBnClickedSearchButton)
                          ON_BN_CLICKED(IDC_SELECT_BUTTON, &CPatientDlg::OnBnClickedSelectButton)
                          END_MESSAGE_MAP()

                          // CPatientDlg message handlers

                          BOOL CPatientDlg::OnInitDialog()
                          {
                          CDialogEx::OnInitDialog();

                          // Set the icon for this dialog.  The framework does this automatically
                          //  when the application's main window is not a dialog
                          SetIcon(m\_hIcon, TRUE);			// Set big icon
                          SetIcon(m\_hIcon, FALSE);		// Set small icon
                          
                          ShowWindow(SW\_MINIMIZE);
                          
                          // TODO: Add extra initialization here
                          m\_strSearch = "Enter name or MRN to search";
                          UpdateData(FALSE);
                          
                          return TRUE;  // return TRUE  unless you set the focus to a control
                          

                          }

                          void CPatientDlg::OnSysCommand(UINT nID, LPARAM lParam)
                          {

                          	CDialogEx::OnSysCommand(nID, lParam);
                          

                          }

                          // If you add a minimize button to your dialog, you will need the code below
                          // to draw the icon. For MFC applications using the document/view model,
                          // this is automatically done for you by the framework.

                          void CPatientDlg::OnPaint()
                          {
                          if (IsIconic())
                          {
                          CPaintDC dc(this); // device context for painting

                          	SendMessage(WM\_ICONERASEBKGND, reinterpret\_cast(dc.GetSafeHdc()), 0);
                          
                          	// Center icon in client rectangle
                          	int cxIcon = GetSystemMetrics(SM\_CXICON);
                          
                          D Offline
                          D Offline
                          David Crow
                          wrote on last edited by
                          #14

                          Member 14575556 wrote:

                          MedicineDlg MedicineObj; MedicineObj.ResetListControl();// Here the code breaks MedicineObj.DatabaseReload();

                          This will not work as it is not the same instance of MedicineDlg that was created in OnBnClickedSelectButton().

                          "One man's wage rise is another man's price increase." - Harold Wilson

                          "Fireproof doesn't mean the fire will never come. It means when the fire comes that you will be able to withstand it." - Michael Simmons

                          "You can easily judge the character of a man by how he treats those who can do nothing for him." - James D. Miles

                          M 1 Reply Last reply
                          0
                          • D David Crow

                            Member 14575556 wrote:

                            MedicineDlg MedicineObj; MedicineObj.ResetListControl();// Here the code breaks MedicineObj.DatabaseReload();

                            This will not work as it is not the same instance of MedicineDlg that was created in OnBnClickedSelectButton().

                            "One man's wage rise is another man's price increase." - Harold Wilson

                            "Fireproof doesn't mean the fire will never come. It means when the fire comes that you will be able to withstand it." - Michael Simmons

                            "You can easily judge the character of a man by how he treats those who can do nothing for him." - James D. Miles

                            M Offline
                            M Offline
                            Member_14575556
                            wrote on last edited by
                            #15

                            Please give some direction how to solves this problem. Thank you.

                            V D 2 Replies Last reply
                            0
                            • M Member_14575556

                              Please give some direction how to solves this problem. Thank you.

                              V Offline
                              V Offline
                              Victor Nijegorodov
                              wrote on last edited by
                              #16

                              You should redesign your project architecture to not directly access one dialog controls from another one.

                              1 Reply Last reply
                              0
                              • M Member_14575556

                                I have included the header file of MedicineDlg (MedicineDlg.h)

                                V Offline
                                V Offline
                                Victor Nijegorodov
                                wrote on last edited by
                                #17

                                It has nothing to do with your problem. See the answer of David below.

                                1 Reply Last reply
                                0
                                • M Member_14575556

                                  Please give some direction how to solves this problem. Thank you.

                                  D Offline
                                  D Offline
                                  David Crow
                                  wrote on last edited by
                                  #18

                                  I would be inclined to change how the data was presented. What you have:

                                  List of data
                                  +---Details of an item in the list
                                  +---Editable view of that item

                                  seems a bit convoluted. I just see too many places for errors, and possibly maintainability. At a minimum, I would combine the last two items. That would go a long way toward solving your immediate problem.

                                  "One man's wage rise is another man's price increase." - Harold Wilson

                                  "Fireproof doesn't mean the fire will never come. It means when the fire comes that you will be able to withstand it." - Michael Simmons

                                  "You can easily judge the character of a man by how he treats those who can do nothing for him." - James D. Miles

                                  1 Reply Last reply
                                  0
                                  Reply
                                  • Reply as topic
                                  Log in to reply
                                  • Oldest to Newest
                                  • Newest to Oldest
                                  • Most Votes


                                  • Login

                                  • Don't have an account? Register

                                  • Login or register to search.
                                  • First post
                                    Last post
                                  0
                                  • Categories
                                  • Recent
                                  • Tags
                                  • Popular
                                  • World
                                  • Users
                                  • Groups