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