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- डेटाबेस संचालन को निष्पादित करने के लिए रीड बटन दबाएं। यह कर्मचारी तालिका को पुनः प्राप्त करेगा।