Apps Script, JDBC सेवा के ज़रिए बाहरी डेटाबेस से कनेक्ट कर सकता है. यह स्टैंडर्ड Java डेटाबेस कनेक्टिविटी टेक्नोलॉजी का रैपर है. JDBC सेवा Google Cloud SQL MySQL, MySQL, Microsoft SQL सर्वर, और Oracle डेटाबेस के साथ काम करती है.
JDBC के साथ किसी बाहरी डेटाबेस को अपडेट करने के लिए, आपकी स्क्रिप्ट को डेटाबेस से एक कनेक्शन खोलना होगा. इसके बाद, SQL स्टेटमेंट भेजकर बदलाव करने होंगे.
Google Cloud SQL डेटाबेस
Google Cloud SQL, आपको रिलेशनल डेटाबेस बनाने देता है जो Google के क्लाउड में रहते हैं. ध्यान रखें कि Apps Script के उलट, Cloud SQL मुफ़्त नहीं है.
आप Cloud SQL क्विकस्टार्ट में दिए गए तरीके को अपनाकर, Google Cloud SQL इंस्टेंस बना सकते हैं.
Google Cloud SQL कनेक्शन बनाना
Apps Script's की JDBC सेवा का इस्तेमाल करके, Google Cloud SQL डेटाबेस से कनेक्शन बनाने के दो तरीके हैं:
- (सुझाया गया) Jdbc.getCloudSqlConnection(url) का इस्तेमाल करके कनेक्ट किया जा रहा है
- Jdbc.getConnection(url) का इस्तेमाल करके कनेक्ट किया जा रहा है
इन तरीकों के बारे में यहां बताया गया है. दोनों मान्य हैं, लेकिन दूसरे तरीके में यह ज़रूरी है कि आप अपने डेटाबेस के ऐक्सेस के लिए आईपी रेंज के सेट की अनुमति दें.
Jdbc.getCloudSqlConnection(url) का इस्तेमाल करें (सुझाया गया)
इस तरीके से Jdbc.getCloudSqlConnection(url)
तरीके का इस्तेमाल करके Google Cloud SQL MySQL इंस्टेंस का कनेक्शन बनाया जाता है. डेटाबेस यूआरएल में jdbc:google:mysql://subname
होता है, जहां subname
, MySQL इंस्टेंस कनेक्शन का नाम होता है. यह Google Cloud Platform Console के Cloud SQL इंस्टेंस खास जानकारी पेज पर दिया जाता है.
Cloud SQL SQL सर्वर से कनेक्ट करने के लिए, Jdbc.getConnection(url) देखें.
Jdbc.getConnection(url) का इस्तेमाल करके
इस तरीके का इस्तेमाल करने के लिए, आपको कुछ सीआईडीआर आईपी पते डालने की अनुमति देनी होगी, ताकि Apps Script' के सर्वर आपके डेटाबेस से कनेक्ट हो सकें. अपनी स्क्रिप्ट चलाने से पहले, नीचे दिए गए चरणों को पूरा करें:
अपने Google Cloud SQL इंस्टेंस में, आईपी रेंज को अनुमति दें, एक बार में एक ही इस डेटा सोर्स से.
अपने डेटाबेस के लिए असाइन किया गया यूआरएल कॉपी करें, इसमें फ़ॉर्म
jdbc:mysql:subname
होना चाहिए.
इन आईपी रेंज को अनुमति देने के बाद, आप Jdbc.getConnection(url) तरीके और ऊपर कॉपी किए गए यूआरएल का इस्तेमाल करके, अपने Google Cloud SQL इंस्टेंस के लिए कनेक्शन बना सकते हैं.
अन्य डेटाबेस
अगर आपके पास पहले से अपना MySQL, Microsoft SQL सर्वर या Oracle डेटाबेस है, तो आप उसे Apps Script और # JDBC सेवा के ज़रिए कनेक्ट कर सकते हैं.
अन्य डेटाबेस कनेक्शन बनाना
डेटाबेस को JDBC सेवा का इस्तेमाल करके बनाने के लिए, आपको अपने डेटाबेस की सेटिंग में कुछ आईपी रेंज को अनुमति देने की अनुमति देनी होगी. ऐसा करने के बाद ही, Apps Script उन्हें ऐक्सेस कर सकेगा. आपको पते की इन सीमाओं को अनुमति देना है.
अनुमति वाली ये सूचियां लागू होने के बाद, आप Jdbc.getConnection(url) तरीके और अपने डेटाबेस के यूआरएल का इस्तेमाल करके, डेटाबेस से कनेक्ट कर सकते हैं.
नमूना कोड
नीचे दिया गया सैंपल कोड यह मानता है कि आप Google Cloud SQL डेटाबेस से कनेक्ट कर रहे हैं और Jdbc.getCloudSqlConnection(url) मैथड का इस्तेमाल करके, डेटाबेस कनेक्शन बनाता है. अन्य डेटाबेस के लिए, आपको डेटाबेस कनेक्शन बनाने के लिए Jdbc.getConnection(url) मैथड का इस्तेमाल करना होगा.
JDBC के तरीकों के बारे में ज़्यादा जानकारी के लिए, JDBC के लिए Java दस्तावेज़ देखें.
कोई डेटाबेस, उपयोगकर्ता, और टेबल बनाएं
ज़्यादातर डेवलपर, डेटाबेस, उपयोगकर्ता, और टेबल बनाने के लिए MySQL कमांड-लाइन टूल का इस्तेमाल करते हैं. हालांकि, जैसा कि नीचे दिखाया गया है, Apps Script में भी वही काम करना संभव है. कम से कम एक और उपयोगकर्ता बनाना एक अच्छा आइडिया है, ताकि आपकी स्क्रिप्ट को हमेशा डेटाबेस से root
के रूप में कनेक्ट न करना पड़े.
डेटाबेस में लिखना
नीचे दिए गए उदाहरणों में बताया गया है कि डेटाबेस के साथ-साथ 500 रिकॉर्ड के बैच को एक ही रिकॉर्ड कैसे लिखा जाएगा. बल्क ऑपरेशन के लिए बैच बनाना ज़रूरी है.
पैरामीटर वाले स्टेटमेंट के इस्तेमाल पर भी ध्यान दें, जिनमें वैरिएबल
को ?
से दिखाया जाता है. SQL इंजेक्शन से बचने के लिए, आपको उपयोगकर्ता से मिले सभी डेटा से बचने के लिए, पैरामीटर वाले स्टेटमेंट का इस्तेमाल करना चाहिए.
डेटाबेस से पढ़ें
यह उदाहरण दिखाता है कि ज़रूरत के हिसाब से सेट किए गए नतीजे पर लूप करके, डेटाबेस से बड़ी संख्या में रिकॉर्ड कैसे पढ़े जाएं.
कनेक्शन बंद किए जा रहे हैं
स्क्रिप्ट के एक्ज़ीक्यूशन के खत्म होने पर JDBC कनेक्शन अपने-आप बंद हो जाते हैं. (ध्यान रखें कि सिर्फ़ एक google.script.run
कॉल की गिनती पूरी एक्ज़ीक्यूशन के तौर पर होती है, भले ही उस एचटीएमएल सेवा पेज पर कोई कार्रवाई न हुई हो जिससे कॉल किया गया था.)
अगर आपको नहीं पता कि स्क्रिप्ट के खत्म होने से पहले आप कनेक्शन, स्टेटमेंट या नतीजे के साथ सेट किया गया है, तो उन्हें JdbcConnection.close()
, JdbcStatement.close()
या JdbcResultSet.close()
पर कॉल करके उन्हें मैन्युअल तरीके से बंद किया जा सकता है.
चेतावनी या प्रॉम्प्ट डायलॉग दिखाने से, JDBC के सभी खुले कनेक्शन भी खत्म हो जाते हैं. हालांकि, दूसरे यूज़र इंटरफ़ेस (यूआई) एलिमेंट दिखाना—जैसे कि कस्टम मेन्यू या डायलॉग और साइडबार वाला कस्टम कॉन्टेंट—नहीं.