Apps Script, JDBC सेवा की मदद से बाहरी डेटाबेस से कनेक्ट हो सकता है. यह सेवा, स्टैंडर्ड Java Database Connectivity टेक्नोलॉजी के चारों ओर मौजूद एक रैपर है. JDBC सेवा, MySQL के लिए Google Cloud SQL, 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 के ट्रेडमार्क हैं. कंपनी और प्रॉडक्ट के अन्य सभी नाम, उन कंपनियों के ट्रेडमार्क हैं जिनसे वे जुड़े हुए हैं.