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