Clojure - Veritabanları

Veritabanı işlevini kullanmak için lütfen önce jdbc files şu url'den - https://codeload.github.com/clojure/java.jdbc/zip/master

Clojure'un veritabanlarına bağlanabilmesi için gerekli sürücüleri içeren bir zip dosyası bulacaksınız. Zip dosyası çıkarıldıktan sonra, sıkıştırılmamış konumu sınıf yolunuza eklediğinizden emin olun.

Veritabanı bağlantısı için ana dosya, jdbc.clj lokasyon clojure / java.

Clojure jdbc konektörü, bazıları aşağıdaki gibi çok çeşitli veritabanlarını destekler.

  • H2Database
  • Oracle
  • Microsoft SQL Sunucusu
  • MySQL
  • PostgreSQL

Örneğimizde, örnek olarak MySQL DB kullanacağız.

Clojure'da Veritabanları ile ilgili olarak aşağıdaki işlemler mümkündür.

Veritabanı Bağlantısı

Bir MySQL veritabanına bağlanmadan önce aşağıdakilerden emin olun -

  • Bir TESTDB veritabanı oluşturdunuz.

  • TESTDB'de EMPLOYEE tablosu oluşturdunuz.

  • Bu tabloda FIRST_NAME, LAST_NAME, AGE, SEX ve INCOME alanları var.

  • "Testuser" kullanıcı kimliği ve "test123" şifresi TESTDB'ye erişmek için ayarlanmıştır.

  • 'Mysql jar dosyasını' indirdiğinizden ve dosyayı sınıf yolunuza eklediğinizden emin olun.

  • MySQL Temellerini anlamak için MySQL eğitiminden geçtiniz .

Sözdizimi

Clojure'da bir bağlantı oluşturmak için sözdizimi aşağıdadır.

(def connection_name {
   :subprotocol “protocol_name”
   :subname “Location of mysql DB”
   :user “username” :password “password” })

Parameters- 'bağlantı_adı' bağlantıya verilecek isimdir. "alt protokol", bağlantı için kullanılacak protokoldür. Varsayılan olarak mysql protokolünü kullanacağız. 'subname', veritabanı adı ile birlikte mysql db'ye bağlanmak için kullanılan url'dir. 'kullanıcı', veritabanına bağlanmak için kullanılan kullanıcı adıdır. 'şifre', veri tabanına bağlanmak için kullanılacak şifredir.

Return Value - Bu, sonraki mysql işlemlerinde kullanılabilecek bir bağlantı dizesi sağlayacaktır.

Aşağıdaki örnek, bilgi şemasındaki tablolara nasıl bağlanılacağını ve tablodaki tüm verilerin nasıl alınacağını gösterir.

Misal

(ns test.core
   (:require [clojure.java.jdbc :as sql]))
(defn -main []
   (def mysql-db {
      :subprotocol "mysql"
      :subname "//127.0.0.1:3306/information_schema"
      :user "root"
      :password "shakinstev"})
   (println (sql/query mysql-db
      ["select table_name from tables"]
      :row-fn :table_name)))

Verileri Sorgulama

Herhangi bir veri tabanındaki verileri sorgulamak, veri tabanından bazı yararlı bilgileri almak anlamına gelir. Bir veritabanı bağlantısı kurulduktan sonra, bu veritabanına bir sorgulama yapmaya hazırsınız. Clojure kullanılarak verilerin sorgulanabileceği sözdizimi aşağıdadır.

Sözdizimi

clojure.java.jdbc/query dbconn
["query"]
   :row-fn :sequence

Parameters- 'dbconn', veritabanına bağlanmak için kullanılan bağlantının adıdır. 'sorgu', veritabanından veri almak için kullanılan sorgu dizesidir. ': sıra' varsayılan olarak veritabanından getirilen tüm veri satırlarıdır ve bir sıra olarak döndürülür. Daha sonra hangi verilerin getirildiğini görmek için sıra üzerinde gerekli işlemler yapılabilir.

Return Value - Bu, sorgu işleminden veri satırlarını içeren bir sıra döndürür.

Aşağıdaki örnek, çalışan tablosuna nasıl bağlanılacağını ve tablodaki satırların ilk_adı sütununun nasıl alınacağını gösterir.

Misal

(ns test.core
   (:require [clojure.java.jdbc :as sql]))
(defn -main []
   (def mysql-db {
      :subprotocol "mysql"
      :subname "//127.0.0.1:3306/testdb"
      :user "root"
      :password "shakinstev"})
   (println (sql/query mysql-db
      ["select first_name from employee"]
      :row-fn :first_name)))

Yukarıdaki koddan bunu görebiliriz

  • Sorgu dizesi olarak “çalışandan birinci_adı seç” sorgusu geçilir.

  • İlk_adı, getirme işleminin bir sonucu olarak döndürülen dizidir.

Veritabanımızda John'un bir first_name değerini içeren tek bir satır olduğunu varsayarsak, aşağıdaki programın çıktısı aşağıdaki olacaktır.

(John)

Veri Ekleme

Kayıtlarınızı bir veritabanı tablosunda oluşturmak istediğinizde gereklidir. Clojure kullanılarak verilerin eklenebileceği sözdizimi aşağıdadır. Bu,‘insert!’ işlevi.

Sözdizimi

clojure.java.jdbc/insert!
   :table_name {:column_namen columnvalue}

Parameters- ': tablo_adı', eklemenin yapılması gereken tablonun adıdır. '{: column_namen columnvalue}', tabloya bir satır olarak eklenmesi gereken tüm sütun adlarının ve değerlerinin bir haritasıdır.

Return Value - Ekleme başarıyla yapılırsa bu sıfır döndürür.

Aşağıdaki örnek, testdb veritabanındaki çalışan tablosuna nasıl kayıt ekleneceğini gösterir.

Misal

(ns test.core
   (:require [clojure.java.jdbc :as sql]))
(defn -main []
   (def mysql-db {
      :subprotocol "mysql"
      :subname "//127.0.0.1:3306/testdb"
      :user "root"
      :password "shakinstev"})
   (sql/insert! mysql-db
      :employee {:first_name "John" :last_name "Mark" :sex "M" :age 30 :income 30}))

Şimdi MySQL veritabanınızı ve çalışan tablosunu kontrol ederseniz, yukarıdaki satırın tabloya başarıyla ekleneceğini göreceksiniz.

Verileri Silme

Bir tablodan satırlar silinebilir. ‘delete!’işlevi. Bu işlemin nasıl gerçekleştirilebileceğine dair sözdizimi aşağıdadır.

Sözdizimi

clojure.java.jdbc/delete!
   :table_name [condition]

Parameters- ': tablo_adı', eklemenin yapılması gereken tablonun adıdır. "koşul", tablodan hangi satırın silinmesi gerektiğini belirlemek için kullanılan koşuldur.

Return Value - Bu, silinen satır sayısını döndürür.

Aşağıdaki örnek, testdb veritabanındaki çalışan tablosundan bir kaydın nasıl silineceğini gösterir. Örnek, yaşın 30'a eşit olması koşuluna göre tablodan bir satırı siler.

Misal

(ns test.core
   (:require [clojure.java.jdbc :as sql]))
(defn -main []
   (def mysql-db {
      :subprotocol "mysql"
      :subname "//127.0.0.1:3306/testdb"
      :user "root"
      :password "shakinstev"})
   (println (sql/delete! mysql-db
      :employee ["age = ? " 30])))

Yaşı 30 değerine eşit bir satıra sahip bir kaydınız varsa, bu satır silinecektir.

Verileri Güncelleme

Bir tablodaki satırlar, ‘update!’işlevi. Bu işlemin nasıl gerçekleştirilebileceğine dair sözdizimi aşağıdadır.

Sözdizimi

clojure.java.jdbc/update!
   :table_name
{setcondition}
[condition]

Parameters- ': tablo_adı', eklemenin yapılması gereken tablonun adıdır. 'setcondition', bir harita açısından belirtildiği gibi güncellenmesi gereken sütundur. "koşul", tablodan hangi satırın silinmesi gerektiğini belirlemek için kullanılan koşuldur.

Return Value - Bu, güncellenen satır sayısını döndürür.

Aşağıdaki örnek, testdb veritabanındaki çalışan tablosundan bir kaydın nasıl silineceğini gösterir. Örnek, yaşın 30'a eşit olması koşuluna göre tablodan bir satırı günceller ve gelir değerini 40 olarak günceller.

(ns test.core
   (:require [clojure.java.jdbc :as sql]))
(defn -main []
   (def mysql-db {
      :subprotocol "mysql"
      :subname "//127.0.0.1:3306/testdb"
      :user "root"
      :password "shakinstev"})
   (println (sql/update! mysql-db
      :employee
      {:income 40}
      ["age = ? " 30])))

Yaşı 30 değerine eşit bir satıra sahip bir kaydınız varsa, bu satır güncellenecek ve burada gelir değeri 40 olarak ayarlanacaktır.

İşlemler

İşlemler, veri tutarlılığını sağlayan mekanizmalardır. İşlemler aşağıdaki dört özelliğe sahiptir -

  • Atomicity - Ya bir işlem tamamlanır ya da hiçbir şey olmaz.

  • Consistency - Bir işlem tutarlı bir durumda başlamalı ve sistemi tutarlı bir durumda bırakmalıdır.

  • Isolation - Bir işlemin ara sonuçları, mevcut işlemin dışında görünmez.

  • Durability - Bir işlem yapıldığında, sistem arızasından sonra bile etkiler kalıcıdır.

Misal

Aşağıdaki örnek Clojure'da işlemlerin nasıl uygulanacağını gösterir. Bir işlemde gerçekleştirilmesi gereken herhangi bir işlemin‘with-dbtransaction’ fıkra.

(ns test.core
   (:require [clojure.java.jdbc :as sql]))
(defn -main []
   (def mysql-db {
      :subprotocol "mysql"
      :subname "//127.0.0.1:3306/testdb"
      :user "root"
      :password "shakinstev"})
   (sql/with-db-transaction [t-con mysql-db]
      (sql/update! t-con
         :employee
         {:income 40}
         ["age = ? " 30])))