MFC - डेटाबेस क्लासेस
ए databaseसूचनाओं का एक संग्रह है जो व्यवस्थित है ताकि इसे आसानी से एक्सेस, प्रबंधित और अपडेट किया जा सके। ODBC पर आधारित MFC डेटाबेस क्लासेस को किसी भी डेटाबेस तक पहुँच प्रदान करने के लिए डिज़ाइन किया गया है, जिसके लिए ODBC ड्राइवर उपलब्ध है। क्योंकि कक्षाएं ODBC का उपयोग करती हैं, इसलिए आपका एप्लिकेशन कई अलग-अलग डेटा प्रारूपों और विभिन्न स्थानीय / दूरस्थ कॉन्फ़िगरेशन में डेटा तक पहुंच सकता है।
आपको अलग-अलग डेटाबेस मैनेजमेंट सिस्टम (DBMS) को संभालने के लिए विशेष-केस कोड लिखने की आवश्यकता नहीं है। जब तक आपके उपयोगकर्ताओं के पास उस डेटा के लिए एक उपयुक्त ODBC ड्राइवर होता है जिसे वे एक्सेस करना चाहते हैं, वे आपके प्रोग्राम का उपयोग वहां संग्रहीत तालिकाओं में डेटा में हेरफेर करने के लिए कर सकते हैं। डेटा स्रोत कुछ डेटाबेस प्रबंधन प्रणाली (DBMS) द्वारा होस्ट किए गए डेटा का एक विशिष्ट उदाहरण है। उदाहरणों में Microsoft SQL सर्वर, Microsoft Access आदि शामिल हैं।
CDatabase
MFC एक वर्ग प्रदान करता है CDatabaseजो डेटा स्रोत से एक कनेक्शन का प्रतिनिधित्व करता है, जिसके माध्यम से आप डेटा स्रोत पर काम कर सकते हैं। आपके आवेदन में एक समय में एक या एक से अधिक सीडीटैब वस्तुएं सक्रिय हो सकती हैं।
अनु क्रमांक। | नाम और विवरण |
---|---|
1 | BeginTrans "लेन-देन" शुरू करता है - AddNew के प्रतिवर्ती कॉल की एक श्रृंखला, संपादित करें, हटाएं और कक्षा के सदस्य कार्यों को अपडेट करें CRecordset- जुड़े डेटा स्रोत पर। डेटा स्रोत के लिए लेनदेन का समर्थन करना चाहिएBeginTrans किसी भी प्रभाव के लिए। |
2 | BindParameters आपको कॉल करने से पहले मापदंडों को बांधने की अनुमति देता है ExecuteSQL। |
3 | Cancel एक एसिंक्रोनस ऑपरेशन या एक दूसरे धागे से एक प्रक्रिया रद्द करता है। |
4 | CanTransact यदि डेटा स्रोत लेनदेन का समर्थन करता है तो नॉनज़रो लौटाता है। |
5 | CanUpdate यदि नॉनजरो लौटाता है तो CDatabase ऑब्जेक्ट अद्यतन करने योग्य है (केवल पढ़ने के लिए नहीं)। |
6 | Close डेटा स्रोत कनेक्शन बंद कर देता है। |
7 | CommitTrans BeginTrans द्वारा शुरू किए गए लेनदेन को पूरा करता है। डेटा स्रोत में परिवर्तन करने वाले लेनदेन में शामिल हैं। |
8 | ExecuteSQL SQL कथन निष्पादित करता है। कोई डेटा रिकॉर्ड वापस नहीं किया जाता है। |
9 | GetBookmarkPersistence उन कार्यों की पहचान करता है जिनके माध्यम से बुकमार्क रिकॉर्ड की गई वस्तुओं पर बने रहते हैं। |
10 | GetConnect डेटा स्रोत से CDatabase ऑब्जेक्ट को कनेक्ट करने के लिए उपयोग किए गए ODBC कनेक्शन स्ट्रिंग लौटाता है। |
1 1 | GetCursorCommitBehavior एक ओपन रिकॉर्डसेट ऑब्जेक्ट पर लेनदेन करने के प्रभाव की पहचान करता है। |
12 | GetCursorRollbackBehavior एक ओपन रिकॉर्डसेट ऑब्जेक्ट पर एक लेन-देन वापस करने के प्रभाव की पहचान करता है। |
13 | GetDatabaseName वर्तमान में उपयोग किए जाने वाले डेटाबेस का नाम लौटाता है। |
14 | IsOpen यदि नॉनजरो लौटाता है तो CDatabase ऑब्जेक्ट वर्तमान में डेटा स्रोत से जुड़ा हुआ है। |
15 | OnSetOptions मानक कनेक्शन विकल्प सेट करने के लिए फ्रेमवर्क द्वारा कॉल किया गया। डिफ़ॉल्ट कार्यान्वयन क्वेरी टाइमआउट मान सेट करता है। आप इन विकल्पों को कॉल करके समय से पहले स्थापित कर सकते हैंSetQueryTimeout। |
16 | Open एक डेटा स्रोत (एक ODBC ड्राइवर के माध्यम से) के लिए एक कनेक्शन स्थापित करता है। |
17 | OpenEx एक डेटा स्रोत (एक ODBC ड्राइवर के माध्यम से) के लिए एक कनेक्शन स्थापित करता है। |
18 | Rollback वर्तमान लेनदेन के दौरान किए गए परिवर्तनों को उलट देता है। डेटा स्रोत अपनी पिछली स्थिति में लौटता है, जैसा कि शुरुआत में कॉल किया जाता है, अनलेडेड। |
19 | SetLoginTimeout सेकंड की संख्या सेट करता है जिसके बाद डेटा स्रोत कनेक्शन का प्रयास समाप्त हो जाएगा। |
20 | SetQueryTimeout सेकंड की संख्या सेट करता है जिसके बाद डेटाबेस क्वेरी ऑपरेशन टाइम आउट हो जाएगा। सभी बाद के रिकॉर्डसेट को प्रभावित करता है, AddNew, Edit, और Delete कॉल। |
एक नया एमएफसी संवाद आधारित एप्लिकेशन बनाकर हमें एक सरल उदाहरण में देखें।
Step 1 - TODO लाइन के कैप्शन को बदलें Retrieve Data from Database और निम्न स्नैपशॉट में दिखाए अनुसार एक बटन और एक सूची नियंत्रण खींचें।
Step 2 - बटन के लिए क्लिक इवेंट हैंडलर जोड़ें और सूची नियंत्रण के लिए चर m_ListControl को नियंत्रित करें।
Step 3 - हमारे पास सरल डेटाबेस है जिसमें कुछ रिकॉर्ड के साथ एक कर्मचारी तालिका है जो निम्न स्नैपशॉट में दिखाया गया है।
Step 4 - हमें निम्नलिखित हेडर फ़ाइल को शामिल करने की आवश्यकता है ताकि हम सीडीटाबेस वर्ग का उपयोग कर सकें।
#include "odbcinst.h"
#include "afxdb.h"
क्वेरी डालें
SQL INSERT INTO स्टेटमेंट का उपयोग डेटाबेस में टेबल पर डेटा की नई पंक्तियों को जोड़ने के लिए किया जाता है।
Step 1 - नए रिकॉर्ड जोड़ने के लिए, हम निम्न कोड में दिखाए गए अनुसार ExatuteSQL () फ़ंक्शन का उपयोग करेंगे।
CDatabase database;
CString SqlString;
CString strID, strName, strAge;
CString sDriver = L"MICROSOFT ACCESS DRIVER (*.mdb)";
CString sDsn;
CString sFile = L"D:\\Test.mdb";
// You must change above path if it's different
int iRec = 0;
// Build ODBC connection string
sDsn.Format(L"ODBC;DRIVER={%s};DSN='';DBQ=%s", sDriver, sFile);
TRY {
// Open the database
database.Open(NULL,false,false,sDsn);
SqlString = "INSERT INTO Employees (ID,Name,age) VALUES (5,'Sanjay',69)";
database.ExecuteSQL(SqlString);
// Close the database
database.Close();
}CATCH(CDBException, e) {
// If a database exception occured, show error msg
AfxMessageBox(L"Database error: " + e→m_strError);
}
END_CATCH;
Step 2 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आप देखेंगे कि आपके डेटाबेस में एक नया रिकॉर्ड जोड़ा गया है।
कीर्तिमान प्राप्त किया
MFC एप्लिकेशन में उपरोक्त तालिका को पुनः प्राप्त करने के लिए, हम बटन ईवेंट हैंडलर में डेटाबेस से संबंधित कार्यों को कार्यान्वित करते हैं जैसा कि निम्नलिखित चरणों में दिखाया गया है।
Step 1- CDatabase का उपयोग करने के लिए, एक CDatabase ऑब्जेक्ट का निर्माण करें और इसके Open () फ़ंक्शन को कॉल करें। इससे कनेक्शन खुल जाएगा।
Step 2 - कनेक्ट किए गए डेटा स्रोत पर काम करने के लिए CRecordset ऑब्जेक्ट्स का निर्माण, अपने CDatabase ऑब्जेक्ट के लिए recordet constructor पॉइंटर पास करें।
Step 3 - कनेक्शन का उपयोग करने के बाद, क्लोज फ़ंक्शन को कॉल करें और सीडीटाबेस ऑब्जेक्ट को नष्ट करें।
void CMFCDatabaseDemoDlg::OnBnClickedButtonRead() {
// TODO: Add your control notification handler code here
CDatabase database;
CString SqlString;
CString strID, strName, strAge;
CString sDriver = "MICROSOFT ACCESS DRIVER (*.mdb)";
CString sFile = L"D:\\Test.mdb";
// You must change above path if it's different
int iRec = 0;
// Build ODBC connection string
sDsn.Format("ODBC;DRIVER={%s};DSN='';DBQ=%s",sDriver,sFile);
TRY {
// Open the database
database.Open(NULL,false,false,sDsn);
// Allocate the recordset
CRecordset recset( &database );
// Build the SQL statement
SqlString = "SELECT ID, Name, Age " "FROM Employees";
// Execute the query
recset.Open(CRecordset::forwardOnly,SqlString,CRecordset::readOnly);
// Reset List control if there is any data
ResetListControl();
// populate Grids
ListView_SetExtendedListViewStyle(m_ListControl,LVS_EX_GRIDLINES);
// Column width and heading
m_ListControl.InsertColumn(0,"Emp ID",LVCFMT_LEFT,-1,0);
m_ListControl.InsertColumn(1,"Name",LVCFMT_LEFT,-1,1);
m_ListControl.InsertColumn(2, "Age", LVCFMT_LEFT, -1, 1);
m_ListControl.SetColumnWidth(0, 120);
m_ListControl.SetColumnWidth(1, 200);
m_ListControl.SetColumnWidth(2, 200);
// Loop through each record
while( !recset.IsEOF() ) {
// Copy each column into a variable
recset.GetFieldValue("ID",strID);
recset.GetFieldValue("Name",strName);
recset.GetFieldValue("Age", strAge);
// Insert values into the list control
iRec = m_ListControl.InsertItem(0,strID,0);
m_ListControl.SetItemText(0,1,strName);
m_ListControl.SetItemText(0, 2, strAge);
// goto next record
recset.MoveNext();
}
// Close the database
database.Close();
}CATCH(CDBException, e) {
// If a database exception occured, show error msg
AfxMessageBox("Database error: "+e→m_strError);
}
END_CATCH;
}
// Reset List control
void CMFCDatabaseDemoDlg::ResetListControl() {
m_ListControl.DeleteAllItems();
int iNbrOfColumns;
CHeaderCtrl* pHeader = (CHeaderCtrl*)m_ListControl.GetDlgItem(0);
if (pHeader) {
iNbrOfColumns = pHeader→GetItemCount();
}
for (int i = iNbrOfColumns; i >= 0; i--) {
m_ListControl.DeleteColumn(i);
}
}
Step 4 - यहां हेडर फाइल है।
// MFCDatabaseDemoDlg.h : header file
//
#pragma once
#include "afxcmn.h"
// CMFCDatabaseDemoDlg dialog
class CMFCDatabaseDemoDlg : public CDialogEx {
// Construction
public:
CMFCDatabaseDemoDlg(CWnd* pParent = NULL); // standard constructor
// Dialog Data
#ifdef AFX_DESIGN_TIME
enum { IDD = IDD_MFCDATABASEDEMO_DIALOG };
#endif
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
void ResetListControl();
// Implementation
protected:
HICON m_hIcon;
// Generated message map functions
virtual BOOL OnInitDialog();
afx_msg void OnPaint();
afx_msg HCURSOR OnQueryDragIcon();
DECLARE_MESSAGE_MAP()
public:
CListCtrl m_ListControl;
afx_msg void OnBnClickedButtonRead();
};
Step 5 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
Step 6- डेटाबेस संचालन को निष्पादित करने के लिए रीड बटन दबाएं। यह कर्मचारी तालिका को पुनः प्राप्त करेगा।
अद्यतन रिकॉर्ड
SQL UPDATE क्वेरी का उपयोग किसी तालिका में मौजूदा रिकॉर्ड को संशोधित करने के लिए किया जाता है। आप चयनित पंक्तियों को अद्यतन करने के लिए UPDATE क्वेरी के साथ जहां खंड का उपयोग कर सकते हैं अन्यथा सभी पंक्तियाँ प्रभावित होंगी।
Step 1 - आइए हम आयु को अपडेट करके एक सरल उदाहरण देखें जहां आईडी 5 के बराबर है।
SqlString = L"UPDATE Employees SET Age = 59 WHERE ID = 5;";
database.ExecuteSQL(SqlString);
Step 2 - यहां बटन क्लिक इवेंट का पूरा कोड है।
void CMFCDatabaseDemoDlg::OnBnClickedButtonRead() {
// TODO: Add your control notification handler code here
CDatabase database;
CString SqlString;
CString strID, strName, strAge;
CString sDriver = L"MICROSOFT ACCESS DRIVER (*.mdb)";
CString sDsn;
CString sFile =
L"C:\\Users\\Muhammad.Waqas\\Downloads\\Compressed\\ReadDB_demo\\Test.mdb";
// You must change above path if it's different
int iRec = 0;
// Build ODBC connection string
sDsn.Format(L"ODBC;DRIVER={%s};DSN='';DBQ=%s", sDriver, sFile);
TRY {
// Open the database
database.Open(NULL,false,false,sDsn);
// Allocate the recordset
CRecordset recset(&database);
SqlString = L"UPDATE Employees SET Age = 59 WHERE ID = 5;";
database.ExecuteSQL(SqlString);
SqlString = "SELECT ID, Name, Age FROM Employees";
// Build the SQL statement
SqlString = "SELECT ID, Name, Age FROM Employees";
// Execute the query
recset.Open(CRecordset::forwardOnly,SqlString,CRecordset::readOnly);
// Reset List control if there is any data
ResetListControl();
// populate Grids
ListView_SetExtendedListViewStyle(m_listCtrl,LVS_EX_GRIDLINES);
// Column width and heading
m_listCtrl.InsertColumn(0,L"Emp ID",LVCFMT_LEFT,-1,0);
m_listCtrl.InsertColumn(1,L"Name",LVCFMT_LEFT,-1,1);
m_listCtrl.InsertColumn(2, L"Age", LVCFMT_LEFT, -1, 1);
m_listCtrl.SetColumnWidth(0, 120);
m_listCtrl.SetColumnWidth(1, 200);
m_listCtrl.SetColumnWidth(2, 200);
// Loop through each record
while (!recset.IsEOF()) {
// Copy each column into a variable
recset.GetFieldValue(L"ID",strID);
recset.GetFieldValue(L"Name",strName);
recset.GetFieldValue(L"Age", strAge);
// Insert values into the list control
iRec = m_listCtrl.InsertItem(0,strID,0);
m_listCtrl.SetItemText(0,1,strName);
m_listCtrl.SetItemText(0, 2, strAge);
// goto next record
recset.MoveNext();
}
// Close the database
database.Close();
}CATCH(CDBException, e) {
// If a database exception occured, show error msg
AfxMessageBox(L"Database error: " + e→m_strError);
}
END_CATCH;
}
Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
Step 4- डेटाबेस संचालन को निष्पादित करने के लिए रीड बटन दबाएं। यह निम्नलिखित कर्मचारी तालिका को पुनः प्राप्त करेगा।
Step 5 - अब आप देख सकते हैं कि आयु 69 से 59 तक अपडेट की गई है।
रिकॉर्ड हटाएं
SQL DELETE क्वेरी का उपयोग किसी तालिका से मौजूदा रिकॉर्ड को हटाने के लिए किया जाता है। आप चयनित पंक्तियों को हटाने के लिए DELETE क्वेरी के साथ WHERE क्लॉज़ का उपयोग कर सकते हैं, अन्यथा सभी रिकॉर्ड हटा दिए जाएंगे।
Step 1 - आइए रिकॉर्ड को हटाकर एक साधारण उदाहरण देखें जहां आईडी 3 के बराबर है।
SqlString = L"DELETE FROM Employees WHERE ID = 3;";
database.ExecuteSQL(SqlString);
Step 2 - यहां बटन क्लिक इवेंट का पूरा कोड है।
void CMFCDatabaseDemoDlg::OnBnClickedButtonRead() {
// TODO: Add your control notification handler code here
CDatabase database;
CString SqlString;
CString strID, strName, strAge;
CString sDriver = L"MICROSOFT ACCESS DRIVER (*.mdb)";
CString sDsn;
CString sFile =
L"C:\\Users\\Muhammad.Waqas\\Downloads\\Compressed\\ReadDB_demo\\Test.mdb";
// You must change above path if it's different
int iRec = 0;
// Build ODBC connection string
sDsn.Format(L"ODBC;DRIVER={%s};DSN='';DBQ=%s", sDriver, sFile);
TRY {
// Open the database
database.Open(NULL,false,false,sDsn);
// Allocate the recordset
CRecordset recset(&database);
SqlString = L"DELETE FROM Employees WHERE ID = 3;";
database.ExecuteSQL(SqlString);
SqlString = "SELECT ID, Name, Age FROM Employees";
// Build the SQL statement
SqlString = "SELECT ID, Name, Age FROM Employees";
// Execute the query
recset.Open(CRecordset::forwardOnly,SqlString,CRecordset::readOnly);
// Reset List control if there is any data
ResetListControl();
// populate Grids
ListView_SetExtendedListViewStyle(m_listCtrl,LVS_EX_GRIDLINES);
// Column width and heading
m_listCtrl.InsertColumn(0,L"Emp ID",LVCFMT_LEFT,-1,0);
m_listCtrl.InsertColumn(1,L"Name",LVCFMT_LEFT,-1,1);
m_listCtrl.InsertColumn(2, L"Age", LVCFMT_LEFT, -1, 1);
m_listCtrl.SetColumnWidth(0, 120);
m_listCtrl.SetColumnWidth(1, 200);
m_listCtrl.SetColumnWidth(2, 200);
// Loop through each record
while (!recset.IsEOF()) {
// Copy each column into a variable
recset.GetFieldValue(L"ID",strID);
recset.GetFieldValue(L"Name",strName);
recset.GetFieldValue(L"Age", strAge);
// Insert values into the list control
iRec = m_listCtrl.InsertItem(0,strID,0);
m_listCtrl.SetItemText(0,1,strName);
m_listCtrl.SetItemText(0, 2, strAge);
// goto next record
recset.MoveNext();
}
// Close the database
database.Close();
}CATCH(CDBException, e) {
// If a database exception occured, show error msg
AfxMessageBox(L"Database error: " + e→m_strError);
}
END_CATCH;
}
Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
Step 4- डेटाबेस संचालन को निष्पादित करने के लिए रीड बटन दबाएं। यह कर्मचारी तालिका को पुनः प्राप्त करेगा।