Access
 sql >> डेटाबेस >  >> RDS >> Access

एक्सेल डेटा स्रोतों के लिए कनेक्शन स्ट्रिंग पैरामीटर्स

एक्सेल डेटा स्रोतों के लिए कनेक्शन स्ट्रिंग पैरामीटर

पिछले लेख में, मैंने चर्चा की थी कि हम एक्सेल और टेक्स्ट फाइलों के साथ कैसे व्यवहार कर सकते हैं जैसे कि वे डीएओ का उपयोग करने वाले डेटाबेस थे, और हम उन्हें बिना लिंक किए कैसे खोल सकते हैं। चूंकि वे ओडीबीसी ड्राइवरों का उपयोग नहीं करते हैं, इसलिए उनकी कनेक्शन स्ट्रिंग को ओडीबीसी कनेक्शन स्ट्रिंग के लिए देखने के आदी होने से काफी अलग स्वरूपित किया जाएगा। एक्सेल कनेक्शन स्ट्रिंग पैरामीटर पर दस्तावेज़ीकरण की कमी है। कुछ कमियों को पाटने और मापदंडों के प्रभाव पर चर्चा करने का यह सबसे अच्छा प्रयास है।

एक्सेल कनेक्शन स्ट्रिंग पैरामीटर

भले ही हमारे पास 3 अलग-अलग डेटा स्रोत "प्रकार" हैं:

  1. Excel 8.0 :97-2003 xls फ़ाइलें
  2. Excel 12.0 :xlsb फ़ाइलें
  3. Excel 12.0 Xml :xlsx फ़ाइलें

वे सभी एक ही पैरामीटर का उपयोग करते हैं।

यहां मापदंडों की सूची दी गई है:

HDR पैरामीटर:हैडर पंक्ति

YES :पहली पंक्ति हेडर है और "टेबल"/"रिकॉर्डसेट" के लिए कॉलम नाम बन जाना चाहिए
NO :पहली पंक्ति को अलग तरीके से नहीं माना जाता है और यह केवल एक डेटा है। सभी कॉलम नामों को "एफएन" नाम दिया जाएगा जहां "एन" 1 से शुरू होने वाली संख्या है

IMEX पैरामीटर:आयात/निर्यात व्यवहार

यह नियंत्रित करता है कि सामग्री के आधार पर कॉलम डेटा प्रकारों को कैसे परिभाषित किया जाना चाहिए:
1 :यदि कॉलम में अलग-अलग डेटा प्रकार हैं, तो इसे एक स्ट्रिंग के रूप में मानें। अन्यथा, कॉलम का मिलान सर्वश्रेष्ठ डेटा प्रकार से करें।
2 :हमेशा नमूने के आधार पर कॉलम का मिलान एक निश्चित डेटा प्रकार से करें। यह पढ़ने में त्रुटि का कारण हो सकता है जब हम एक ऐसी पंक्ति पढ़ते हैं जिसमें डेटा होता है जो अपेक्षित डेटा प्रकार से मेल नहीं खाता है।

ACCDB पैरामीटर:इंगित करता है कि एक्सेस ACCDB फ़ाइल स्वरूप का उपयोग कर रहा है?

डिफ़ॉल्ट रूप से, यह हमेशा ACCDB=YES को accdb फ़ाइल स्वरूप में सेट किया जाता है। हालाँकि, इसे छोड़ना या इसे NO पर सेट करना कुछ भी नहीं लगता है। यह थोड़ा रहस्य है। अगर कोई इस पैरामीटर के प्रभाव को साझा कर सकता है, तो टिप्पणी में पोस्ट करें और मैं ब्लॉग को अपडेट कर दूंगा।

डेटाबेस:एक्सेल वर्कबुक का पथ

पैरामीटर में कार्यपुस्तिका के नाम सहित पूरी तरह से योग्य पथ होना चाहिए।

न्यूनतम कार्यशील कनेक्शन स्ट्रिंग

ध्यान दें कि डेटा प्रकार स्रोत कीवर्ड के अतिरिक्त केवल DATABASE ही अनिवार्य पैरामीटर है। इसलिए एक न्यूनतम कार्यशील कनेक्शन स्ट्रिंग हो सकती है:

Excel 8.0;DATABASE=C:\Links\Products.xls

कनेक्शन स्ट्रिंग में शीट या श्रेणी निर्दिष्ट करना

पिछले नमूने में, आपने देखा था कि एक शीट “DAO.TableDef . का प्रतिनिधित्व करती है ". हालांकि, वर्कशीट ही एकमात्र ऐसी चीज नहीं है जो "Tabledef . हो सकती है ". यदि एक्सेल स्प्रेडशीट में एक नामित श्रेणी है, तो नामित श्रेणी को "Tabledef . के रूप में रिपोर्ट किया जाएगा " भी। इसके अतिरिक्त, हम सेल पते का उपयोग करके शीट में एक मनमाना ब्लॉक "क्वेरी" कर सकते हैं। उदाहरण के लिए:

Dim db As DAO.Database
Dim rs As DAO.Recordset

Set db = DBEngine.OpenDatabase(vbNullString, False, False, "Excel 12.0 Xml;HDR=YES;IMEX=2;ACCDB=YES;DATABASE=C:\Links\Products.xlsx")
Set rs = db.OpenRecordsset("Sheet$1A1:A3")

Debug.Print rs.Name, rs.Fields.Count

यह नोट करना महत्वपूर्ण है कि सेल के पते शीट की उपयोग की गई सीमा से अधिक नहीं हो सकते। उदाहरण के लिए, Products.xlsx केवल वास्तव में A1:B3 में सामग्री है, इसका मतलब है कि यदि आप शीट1$A1:D5 का उपयोग करके एक रिकॉर्डसेट खोलते हैं, तो भी आपको फ़ील्ड गणना के लिए केवल 2 और रिकॉर्ड गणना के लिए 3 मिलते हैं। अतिरिक्त खाली कॉलम/पंक्तियों को केवल अनदेखा कर दिया जाता है। दूसरी तरफ, अगर आपने A1:B3 . के बाहर कहीं किसी सेल को गंदा किया है , शीट का UsedRange अब उतना ही बड़ा होगा और क्वेरी करने में खाली कॉलम और पंक्तियाँ शामिल होंगी।

इसलिए एक्सेल "डेटाबेस" पर एक क्वेरी में उपयोग करने के लिए वे मान्य नाम हैं:

  1. Sheet1$ - वर्कशीट की पूरी इस्तेमाल की गई रेंज।
  2. Sheet1$A1:B4 - केवल 2 कॉलम और 3 पंक्तियाँ (हेडर की गिनती नहीं), बशर्ते कि सामग्री भरी हुई हो। अन्यथा कॉलम या पंक्तियाँ अनुरोध से कम हो सकती हैं।
  3. ProductsRange - उस नाम के साथ नामित श्रेणी।

मुझे नामित श्रेणियों का उपयोग करना बहुत अच्छा लगता है जहां व्यावहारिक यह सुनिश्चित करता है कि आप अपने कोड में पतों को हार्ड-कोडिंग नहीं कर रहे हैं, खासकर यदि उपयोगकर्ता द्वारा नए कॉलम या पंक्तियों को सम्मिलित करने के कारण रेंज इधर-उधर हो जाती है, लेकिन नामित श्रेणी की सामग्री में परिवर्तन नहीं होता है . हालांकि यह हमेशा व्यावहारिक नहीं होता है, खासकर यदि आप किसी तृतीय पक्ष से स्प्रैडशीट प्राप्त कर रहे हैं और इसलिए इसकी सामग्री या प्रारूपों पर आपका कोई नियंत्रण नहीं है। इस मामले में, SQL क्वेरी लिखना भी काम कर सकता है।

Excel डेटा स्रोत की क्वेरी करना

मान लीजिए कि हम प्रारूप को नियंत्रित नहीं कर सकते हैं और हम पूर्ण पते पर भरोसा नहीं करना चाहते हैं, हालांकि हमें विश्वास है कि कुछ कॉलम और पंक्तियां वास्तव में मौजूद होंगी। उस स्थिति में, पूछताछ करना सबसे अच्छी बात है। यहां एक उदाहरण दिया गया है जो केवल एक पंक्ति का चयन करता है:

  Dim db As DAO.Database
  Set db = DBEngine.OpenDatabase(vbNullString, False, False, "Excel 12.0 Xml;HDR=YES;IMEX=2;ACCDB=YES;DATABASE=C:\Links\Products.xlsx")

  Dim rs As DAO.Recordset
  Set rs = db.OpenRecordset("SELECT d.[Count] FROM [Sheet1$] AS d WHERE d.[Products] = 'Bananas';")
  Debug.Print rs.Fields(0).Value

उम्मीद है कि आप देख सकते हैं कि प्रत्येक पंक्तियों पर पुनरावृत्ति करने से यह पता लगाना बहुत आसान है कि किसके पास "केले" हैं और फिर गिनती प्राप्त करने के लिए कॉलम को दाईं ओर पढ़ना है। इस मामले में, क्वेरी करना एक्सेल को स्वचालित करने से पीछे हट जाता है।

निष्कर्ष

आपने देखा है कि डीएओ हमारे लिए एक्सेल डेटा स्रोत के साथ काम करना बहुत आसान बनाता है और यह दिखावा करता है कि यह एक रिलेशनल डेटा स्रोत था और वीबीए कोड का गुच्छा लिखने के बजाय हमारी पसंदीदा क्वेरीिंग भाषा और परिचित डीएओ ऑब्जेक्ट्स का उपयोग करता है जो एक्सेल को खोजने के लिए स्वचालित करता है। डेटा हम चाहते हैं। कनेक्शन स्ट्रिंग पैरामीटर काफी सीधे हैं और जब तक आपके पास पथ है, आप एक्सेल स्प्रेडशीट को जोड़ने या खोलने के लिए अच्छे हैं।

अगले लेख में हम टेक्स्ट फ़ाइल कनेक्शन पैरामीटर देखेंगे।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. क्या माइक्रोसॉफ्ट एक्सेस सीखना आसान है?

  2. इन-मेमोरी OLTP डेटाबेस और टेबल्स बनाना और एक्सेस करना

  3. एमएस एक्सेस:फायदे और नुकसान

  4. स्टेटिक फ़ंक्शंस और सब्स

  5. डेटाबेस एक्सेस अनुमतियां सेट करना