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