अपाचे प्रेस्टो - 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