Apache Presto - MySQL Bağlayıcısı
MySQL bağlayıcısı, harici bir MySQL veritabanını sorgulamak için kullanılır.
Önkoşullar
MySQL sunucu kurulumu.
Yapılandırma ayarları
Umarım makinenize mysql sunucusu kurmuşsunuzdur. Presto sunucusunda mysql özelliklerini etkinleştirmek için bir dosya oluşturmanız gerekir“mysql.properties” içinde “etc/catalog”dizin. Bir mysql.properties dosyası oluşturmak için aşağıdaki komutu çalıştırın.
$ cd etc
$ cd catalog
$ vi mysql.properties
connector.name = mysql
connection-url = jdbc:mysql://localhost:3306
connection-user = root
connection-password = pwd
Dosyayı kaydedin ve terminalden çıkın. Yukarıdaki dosyada mysql şifrenizi bağlantı-şifre alanına girmelisiniz.
MySQL Sunucusunda Veritabanı Oluşturun
MySQL sunucusunu açın ve aşağıdaki komutu kullanarak bir veritabanı oluşturun.
create database tutorials
Artık sunucuda “öğreticiler” veritabanı oluşturdunuz. Veritabanı türünü etkinleştirmek için sorgu penceresinde "öğreticileri kullan" komutunu kullanın.
Tablo Oluştur
"Öğreticiler" veritabanı üzerinde basit bir tablo oluşturalım.
create table author(auth_id int not null, auth_name varchar(50),topic varchar(100))
Tablo Ekle
Bir tablo oluşturduktan sonra, aşağıdaki sorguyu kullanarak üç kayıt ekleyin.
insert into author values(1,'Doug Cutting','Hadoop')
insert into author values(2,’James Gosling','java')
insert into author values(3,'Dennis Ritchie’,'C')
Kayıtları Seçin
Tüm kayıtları almak için aşağıdaki sorguyu yazın.
Sorgu
select * from author
Sonuç
auth_id auth_name topic
1 Doug Cutting Hadoop
2 James Gosling java
3 Dennis Ritchie C
Şu an itibariyle, MySQL sunucusunu kullanarak verileri sorguladınız. Mysql depolama eklentisini Presto sunucusuna bağlayalım.
Presto CLI'yi bağlayın
MySql eklentisini Presto CLI'ye bağlamak için aşağıdaki komutu yazın.
./presto --server localhost:8080 --catalog mysql --schema tutorials
Aşağıdaki yanıtı alacaksınız.
presto:tutorials>
Buraya “tutorials” mysql sunucusundaki şemayı ifade eder.
Şemaları Listele
Mysql'deki tüm şemaları listelemek için Presto sunucusuna aşağıdaki sorguyu yazın.
Sorgu
presto:tutorials> show schemas from mysql;
Sonuç
Schema
--------------------
information_schema
performance_schema
sys
tutorials
Bu sonuçtan, ilk üç şemayı önceden tanımlanmış ve sonuncusu kendi oluşturduğunuz şekilde sonuçlandırabiliriz.
Şemadan Tabloları Listeleme
Aşağıdaki sorgu, öğreticiler şemasındaki tüm tabloları listeler.
Sorgu
presto:tutorials> show tables from mysql.tutorials;
Sonuç
Table
--------
author
Bu şemada sadece bir tablo oluşturduk. Birden çok tablo oluşturduysanız, tüm tabloları listeler.
Tabloyu Açıklayın
Tablo alanlarını açıklamak için aşağıdaki sorguyu yazın.
Sorgu
presto:tutorials> describe mysql.tutorials.author;
Sonuç
Column | Type | Comment
-----------+--------------+---------
auth_id | integer |
auth_name | varchar(50) |
topic | varchar(100) |
Tablodaki Sütunları Göster
Sorgu
presto:tutorials> show columns from mysql.tutorials.author;
Sonuç
Column | Type | Comment
-----------+--------------+---------
auth_id | integer |
auth_name | varchar(50) |
topic | varchar(100) |
Tablo Kayıtlarına Erişim
Tüm kayıtları mysql tablosundan almak için aşağıdaki sorguyu çalıştırın.
Sorgu
presto:tutorials> select * from mysql.tutorials.author;
Sonuç
auth_id | auth_name | topic
---------+----------------+--------
1 | Doug Cutting | Hadoop
2 | James Gosling | java
3 | Dennis Ritchie | C
Bu sonuçtan, Presto'da mysql sunucu kayıtlarını alabilirsiniz.
Komut Olarak Kullanarak Tablo Oluşturun
Mysql bağlayıcısı tablo oluşturma sorgusunu desteklemez, ancak komut olarak kullanarak bir tablo oluşturabilirsiniz.
Sorgu
presto:tutorials> create table mysql.tutorials.sample as
select * from mysql.tutorials.author;
Sonuç
CREATE TABLE: 3 rows
Bu bağlayıcının bazı sınırlamaları olduğundan doğrudan satır ekleyemezsiniz. Aşağıdaki sorguları destekleyemez -
- create
- insert
- update
- delete
- drop
Yeni oluşturulan tablodaki kayıtları görüntülemek için aşağıdaki sorguyu yazın.
Sorgu
presto:tutorials> select * from mysql.tutorials.sample;
Sonuç
auth_id | auth_name | topic
---------+----------------+--------
1 | Doug Cutting | Hadoop
2 | James Gosling | java
3 | Dennis Ritchie | C