MFC实现数据库数据读取与展示 (mfc读取数据库数据并显示)
MFC是Microsoft Foundation Classes的缩写,是一个基于C++的类库。作为Windows下经典的GUI编程框架之一,MFC提供了一系列的类和函数,可以帮助我们很方便地开发Windows应用程序。在其中,MFC的数据库支持是一个很重要的功能,可以方便地处理数据库操作。本篇文章将介绍如何使用的功能。
MFC数据库类
MFC中提供了丰富的数据库操作类,如CDatabase,CRecordset等。其中CDatabase类用于连接数据库,并获取数据库的使用权限;CRecordset则是用于执行SQL语句,并从结果集中读取数据的。MFC中还提供了许多派生自CRecordset的类,以便读取不同类型的数据库表格数据。
创建MFC应用程序
需要创建一个MFC应用程序。这里我们选择使用Visual Studio 2023创建一个SDI(单文档应用程序)。在创建过程中,选择“使用数据库”选项,所选择的数据库为SQL Server。在数据库连接字符串中输入服务器名称、数据库名称以及账户名和密码,完成后即可创建应用程序。
连接SQL Server数据库
接下来,我们需要在CWinApp派生类的InitInstance函数中连接SQL Server数据库。我们需要包含头文件afxdb.h,以便使用MFC数据库相关的类和函数。然后,在InitInstance中添加如下代码,连接SQL Server数据库。
“`c++
BOOL CMyApp::InitInstance()
{
AfxEnableControlContner();
//创建主窗口
…
//连接数据库
CDatabase database;
CString strSqlConnect;
strSqlConnect.Format(_T(“ODBC;DSN=SQL Server;UID=%s;PWD=%s”),
_T(“sa”), _T(“123456”));
if (!database.Open(NULL, FALSE, FALSE, strSqlConnect)) {
AfxMessageBox(_T(“Can’t connect to the database”));
return FALSE;
}
//运行主窗口
m_pMnWnd->ShowWindow(SW_SHOW);
m_pMnWnd->UpdateWindow();
return TRUE;
}
“`
SQL Server数据库连接字符串的格式可以是ODBC或SQL Server本地连接,这里我们选择使用ODBC连接方式。其中,DSN参数指的是ODBC数据源名称。UID和PWD则是数据库的登录账户和密码,这里我们使用默认的sa账户和密码。如果连接失败,则会提示一个信息框。
执行SQL语句
在数据库连接成功后,我们就可以执行SQL语句了。这里我们使用派生自CRecordset的类CMyRecordset来读取数据库表格数据。假设我们需要从一个名为Employee的表格中读取所有员工的信息。那么,首先需要在应用程序的头文件中添加CMyRecordset的定义:
“`c++
class CMyRecordset : public CRecordset
{
public:
CMyRecordset(CDatabase* pDatabase = NULL);
// 字段/列数据
public:
CString m_Id;
CString m_Name;
int m_Age;
CString m_Gender;
CString m_Address;
//…其他列
// 重写
public:
virtual CString GetDefaultConnect();
virtual CString GetDefaultSQL();
virtual void DoFieldExchange(CFieldExchange* pFX);
// 实现
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
};
“`
然后,在CMyRecordset的实现文件中,添加以下代码:
“`c++
CString CMyRecordset::GetDefaultConnect()
{
return _T(“ODBC;DSN=SQL Server;UID=sa;PWD=123456”);
}
CString CMyRecordset::GetDefaultSQL()
{
return _T(“SELECT * FROM Employee”);
}
void CMyRecordset::DoFieldExchange(CFieldExchange* pFX)
{
pFX->SetFieldType(CFieldExchange::outputColumn);
RFX_Text(pFX, _T(“[Id]”), m_Id);
RFX_Text(pFX, _T(“[Name]”), m_Name);
RFX_Int(pFX, _T(“[Age]”), m_Age);
RFX_Text(pFX, _T(“[Gender]”), m_Gender);
RFX_Text(pFX, _T(“[Address]”), m_Address);
//…其他列
}
“`
GetDefaultConnect函数用于返回连接字符串,GetDefaultSQL函数则声明执行的SQL语句。DoFieldExchange函数则用于将每一列的数据读取到相应的成员变量中。
接下来,在主窗口的OnInitDialog函数中,添加以下代码:
“`c++
BOOL CMyDlg::OnInitDialog()
{
CDialogEx::OnInitDialog();
//…
CMyRecordset rs;
rs.Open(CRecordset::snapshot, NULL, CRecordset::readOnly);
while (!rs.IsEOF()) {
m_listCtrl.InsertItem(0, rs.m_Id);
m_listCtrl.SetItemText(0, 1, rs.m_Name);
m_listCtrl.SetItemText(0, 2, CString(rs.m_Age));
m_listCtrl.SetItemText(0, 3, rs.m_Gender);
m_listCtrl.SetItemText(0, 4, rs.m_Address);
//…其他列
rs.MoveNext();
}
rs.Close();
//…
return TRUE;
}
“`
在这个代码段中,我们首先创建CMyRecordset对象rs,并调用Open函数打开结果集。CRecordset::snapshot用于指示查询结果集是一个快照(不是一个直接的数据库游标),CRecordset::readOnly则指示结果集以只读方式打开(不可编辑)。然后,在一个while循环中,我们循环遍历整个结果集,将每一行的数据插入到m_listCtrl控件中的对应行中。注意,我们是从后往前插入数据的,以便保证新加入的数据总是在表格的最上方。我们通过rs.Close函数关闭结果集,完成查询操作。
编译与调试
至此,通过以上步骤,我们就已经完成了的功能。在进行编译之前,确保已连接到正确的数据库,并且表格中已包含了我们需要的数据。然后,编译并构建应用程序,启动程序后即可看到查询结果在m_listCtrl控件中显示出来的效果。
本篇文章主要介绍了如何使用的功能。我们首先创建了一个MFC应用程序,然后连接SQL Server数据库,通过派生自CRecordset的类CMyRecordset,选取了需要查询的Employee表格中的全部数据,并将结果展示在m_listCtrl控件中。相信读者在阅读了本文后,对于如何使用MFC来读取和展示数据库数据,有了更加深入的了解。