अपाचे प्रेस्टो - MySQL कनेक्टर

MySQL कनेक्टर का उपयोग किसी बाहरी MySQL डेटाबेस को क्वेरी करने के लिए किया जाता है।

आवश्यक शर्तें

MySQL सर्वर इंस्टालेशन।

कॉन्फ़िगरेशन सेटिंग्स

उम्मीद है कि आपने mysql सर्वर को अपनी मशीन पर स्थापित किया होगा। Presto सर्वर पर mysql प्रॉपर्टीज़ को सक्षम करने के लिए, आपको एक फ़ाइल बनानी होगी“mysql.properties” में “etc/catalog”निर्देशिका। Mysql.properties फ़ाइल बनाने के लिए निम्न आदेश जारी करें।

$ cd etc 
$ cd catalog 
$ vi mysql.properties   

connector.name = mysql 
connection-url = jdbc:mysql://localhost:3306 
connection-user = root 
connection-password = pwd

फ़ाइल सहेजें और टर्मिनल से बाहर निकलें। उपरोक्त फ़ाइल में, आपको कनेक्शन-पासवर्ड फ़ील्ड में अपना mysql पासवर्ड दर्ज करना होगा।

MySQL सर्वर में डेटाबेस बनाएँ

MySQL सर्वर खोलें और निम्नलिखित कमांड का उपयोग करके एक डेटाबेस बनाएं।

create database tutorials

अब आपने सर्वर में "ट्यूटोरियल" डेटाबेस बनाया है। डेटाबेस प्रकार को सक्षम करने के लिए, क्वेरी विंडो में "ट्यूटोरियल का उपयोग करें" कमांड का उपयोग करें।

तालिका बनाएं

चलो "ट्यूटोरियल" डेटाबेस पर एक सरल तालिका बनाते हैं।

create table author(auth_id int not null, auth_name varchar(50),topic varchar(100))

तलिका डालें

तालिका बनाने के बाद, निम्नलिखित क्वेरी का उपयोग करके तीन रिकॉर्ड डालें।

insert into author values(1,'Doug Cutting','Hadoop') 
insert into author values(2,’James Gosling','java') 
insert into author values(3,'Dennis Ritchie’,'C')

रिकॉर्ड का चयन करें

सभी रिकॉर्ड पुनर्प्राप्त करने के लिए, निम्न क्वेरी टाइप करें।

सवाल

select * from author

परिणाम

auth_id    auth_name      topic  
1        Doug Cutting     Hadoop 
2        James Gosling    java 
3        Dennis Ritchie     C

अब तक, आपने MySQL सर्वर का उपयोग करके डेटा को क्वेर किया है। चलिए Presto सर्वर से Mysql स्टोरेज प्लगइन को कनेक्ट करते हैं।

कनेक्ट प्रेस्टो सीएलआई

Presto CLI पर MySql plugin को कनेक्ट करने के लिए निम्न कमांड टाइप करें।

./presto --server localhost:8080 --catalog mysql --schema tutorials

आपको निम्न प्रतिक्रिया प्राप्त होगी।

presto:tutorials>

यहाँ “tutorials” mysql सर्वर में स्कीमा को संदर्भित करता है।

योजनाओं को सूचीबद्ध करें

Mysql में सभी स्कीमाओं को सूचीबद्ध करने के लिए, प्रेस्टो सर्वर में निम्नलिखित क्वेरी टाइप करें।

सवाल

presto:tutorials> show schemas from mysql;

परिणाम

Schema 
-------------------- 
 information_schema 
 performance_schema 
 sys 
 tutorials

इस परिणाम से, हम पहले तीन स्कीमाओं को पूर्वनिर्धारित के रूप में समाप्त कर सकते हैं और अंतिम स्वयं के रूप में बनाया जा सकता है।

स्कीमों से सूची सूची

क्वेरी के बाद ट्यूटोरियल स्कीमा में सभी तालिकाओं को सूचीबद्ध करता है।

सवाल

presto:tutorials> show tables from mysql.tutorials;

परिणाम

Table 
-------- 
 author

हमने इस स्कीमा में केवल एक तालिका बनाई है। यदि आपने कई तालिकाएँ बनाई हैं, तो यह सभी तालिकाओं को सूचीबद्ध करेगी।

तालिका का वर्णन करें

तालिका फ़ील्ड का वर्णन करने के लिए, निम्न क्वेरी टाइप करें।

सवाल

presto:tutorials> describe mysql.tutorials.author;

परिणाम

Column   |     Type     | Comment 
-----------+--------------+--------- 
 auth_id   | integer      | 
 auth_name | varchar(50)  | 
 topic     | varchar(100) |

तालिका से कॉलम दिखाएं

सवाल

presto:tutorials> show columns from mysql.tutorials.author;

परिणाम

Column    |     Type     | Comment 
-----------+--------------+--------- 
 auth_id   | integer      | 
 auth_name | varchar(50)  | 
 topic     | varchar(100) |

एक्सेस टेबल रिकॉर्ड

Mysql तालिका से सभी रिकॉर्ड लाने के लिए, निम्नलिखित क्वेरी जारी करें।

सवाल

presto:tutorials> select * from mysql.tutorials.author;

परिणाम

auth_id  |   auth_name    | topic 
---------+----------------+-------- 
       1 | Doug Cutting   | Hadoop 
       2 | James Gosling  | java 
       3 | Dennis Ritchie | C

इस परिणाम से, आप प्रेस्टो में mysql सर्वर रिकॉर्ड प्राप्त कर सकते हैं।

कमांड के रूप में तालिका का उपयोग करें

Mysql कनेक्टर टेबल क्वेरी बनाने का समर्थन नहीं करता है, लेकिन आप कमांड के रूप में उपयोग करके एक टेबल बना सकते हैं।

सवाल

presto:tutorials> create table mysql.tutorials.sample as 
select * from mysql.tutorials.author;

परिणाम

CREATE TABLE: 3 rows

आप सीधे पंक्तियाँ नहीं डाल सकते क्योंकि इस कनेक्टर की कुछ सीमाएँ हैं। यह निम्नलिखित प्रश्नों का समर्थन नहीं कर सकता है -

  • create
  • insert
  • update
  • delete
  • drop

नए बनाए गए तालिका में रिकॉर्ड देखने के लिए, निम्न क्वेरी टाइप करें।

सवाल

presto:tutorials> select * from mysql.tutorials.sample;

परिणाम

auth_id  |   auth_name    | topic 
---------+----------------+-------- 
       1 | Doug Cutting   | Hadoop 
       2 | James Gosling  | java 
       3 | Dennis Ritchie | C