TOP

VBA Excel का उपयोग करके SQL क्वेरी

विवरण

बाहरी स्रोतों से वर्कशीट में डेटा प्राप्त करने के कई तरीके हैं Excel . इस आलेख में, हम देखेंगे कि डेटाबेस फ़ाइल से डेटा की क्वेरी कैसे करें MS Access और एक फ़ाइल से Excel का उपयोग करके एसक्यूएल में VBA . हाँ, हम इसे थोड़ा मिश्रित करने जा रहे हैं SQL साथ VBA ! और यह जितना आप सोच सकते हैं उससे बेहतर है!

SQL के लिए खड़ा है Structured Query Language (संरचित क्वेरी भाषा) और डेटाबेस से जानकारी प्राप्त करने के लिए उपयोग की जाने वाली भाषा है (जैसे MS Access, MS SQL Server, Oracle, Sybase, SAP, MySQL और दूसरे)।

आप इंटरनेट, टेक्स्ट फ़ाइलों या अन्य Excel से भी डेटा प्राप्त कर सकते हैं CSV फ़ाइलें.


1. Excel VBA से फ़ाइल MS Access तक SQL क्वेरी

इसलिए हमें एक डेटाबेस कनेक्शन (वेरिएबल) की आवश्यकता है varConn नीचे मैक्रो में) और एसक्यूएल क्वेरी (चर varSQL ) रिपोर्ट के लिए डेटाबेस से डेटा की पुनर्प्राप्ति को स्वचालित करने के लिए। नीचे दिए गए उदाहरण में है एसक्यूएल क्वेरी , जो MS Access में एक छोटे डेटाबेस से डेटा प्राप्त करता है।

क्लिक डेटाबेस लोड करें MS Access (test.mdb) .

MS Access फ़ाइल इस तरह दिखेगी:

आइए अपना मैक्रो लिखें जो निष्पादित होगा एसक्यूएल क्वेरी .

मेनू खोलें सेवा - मैक्रो - संपादक Visual Basic , नया मॉड्यूल डालें (मेन्यू Insert - Modle ) और वहां मैक्रो टेक्स्ट कॉपी करें:

  1. Sub SQLQuery_1()  
  2. 'moonexcel.com.ua  
  3. Dim varConn As String  
  4. Dim varSQL  As String  
  5.   
  6.     Range("A1").CurrentRegion.ClearContents  
  7.   
  8.     varConn = "ODBC;Driver={Microsoft Access Driver (*.mdb, *.accdb)}"  
  9.   
  10.     varSQL = "SELECT Month, Product, City FROM Sumproduct"  
  11.   
  12.          With ActiveSheet.QueryTables.Add(Connection:=varConn, Destination:=Range("A1"))  
  13.              .CommandText = varSQL  
  14.              .Refresh BackgroundQuery:=False  
  15.          End With  
  16. End Sub   

सहेजें पर क्लिक करें और Excel पर वापस लौटें। मेनू से चुनें देखें - मैक्रोज़ (Alt+F8) हमारे मैक्रो का नाम " SQLQuery_1 ". एक डायलॉग बॉक्स दिखाई देगा, उसे दबाएं डेटाबेस... , हमारी एक्सेस फ़ाइल देखें और क्लिक करें ОК .

अब हम देख सकते हैं कि हमारी मैक्रो क्वेरी ने कॉलम खींच लिए हैं Month , Product और City मेज से Sumproduct डेटाबेस से test.mdb Excel फ़ाइल करने के लिए।

2. VBA से बंद फ़ाइल Excel तक SQL क्वेरी

इसी प्रकार, हम एक नियमित Excel फ़ाइल से डेटा प्राप्त कर सकते हैं जैसे कि किसी डेटाबेस से। इसके लिए हमारे मैक्रो के कोड को थोड़ा दोबारा लिखना होगा और कनेक्शन ड्राइवर को Access से Excel में बदलना होगा।

हम तालिका निर्यात करते हैं Sumproduct Excel में एक्सेस से और फ़ाइल को सेव करें। इसके बाद, हम अपना संशोधित कोड एक नए मॉड्यूल में डालते हैं और मैक्रो चलाते हैं:

  1. Sub SQLQuery_2()  
  2. 'moonexcel.com.ua  
  3. Dim varConn As String  
  4. Dim varSQL  As String  
  5.   
  6.     Range("A1").CurrentRegion.ClearContents  
  7.   
  8.     varConn = "ODBC;Driver={Microsoft Excel Driver (*.xls, *.xlsx, *.xlsm, *.xlsb)}"  
  9.   
  10.     varSQL = "SELECT Month, Product, City FROM Sumproduct"  
  11.   
  12.          With ActiveSheet.QueryTables.Add(Connection:=varConn, Destination:=Range("A1"))  
  13.              .CommandText = varSQL  
  14.              .Refresh BackgroundQuery:=False  
  15.          End With  
  16. End Sub   

एक विंडो दिखाई देगी जहां हम अपनी Excel फ़ाइल का चयन कर सकते हैं (जिसे कॉल किया जाना चाहिए)। Sumproduct.xlsx या किसी अन्य एक्सटेंशन के साथ)। हम इसे ढूंढते हैं और चुनते हैं। चलो दबाओ ОК , और हमें वही डेटा मिलता है जो एक्सेस फ़ाइल से मिलता है।

विषय पर लेख: