Lua - Akses Database

Untuk operasi data sederhana, kami dapat menggunakan file, tetapi, terkadang, operasi file ini mungkin tidak efisien, dapat diskalakan, dan bertenaga. Untuk tujuan ini, kita mungkin sering beralih menggunakan database. LuaSQL adalah antarmuka sederhana dari Lua ke sejumlah sistem manajemen basis data. LuaSQL adalah pustaka yang menyediakan dukungan untuk berbagai jenis SQL. Ini termasuk,

  • SQLite
  • Mysql
  • ODBC

Dalam tutorial ini, kita akan membahas penanganan database MySQL dan SQLite di Lua. Ini menggunakan antarmuka generik untuk keduanya dan harus memungkinkan untuk port implementasi ini ke jenis database lain juga. Pertama mari kita lihat bagaimana Anda dapat melakukan operasi di MySQL.

Pengaturan db MySQL

Untuk menggunakan contoh berikut agar berfungsi seperti yang diharapkan, kita memerlukan penyiapan db awal. Asumsinya tercantum di bawah ini.

  • Anda telah menginstal dan mengatur MySQL dengan pengguna default sebagai root dan kata sandi sebagai '123456'.

  • Anda telah membuat tes database.

  • Anda telah melalui tutorial MySQL untuk memahami Dasar-Dasar MySQL.

Mengimpor MySQL

Kita bisa menggunakan yang sederhana require pernyataan untuk mengimpor pustaka sqlite dengan asumsi bahwa implementasi Lua Anda dilakukan dengan benar.

mysql = require "luasql.mysql"

Variabel mysql akan memberikan akses ke fungsi-fungsi dengan mengacu pada tabel mysql utama.

Menyiapkan Koneksi

Kita dapat mengatur koneksi dengan memulai lingkungan MySQL dan kemudian membuat koneksi untuk lingkungan tersebut. Itu ditunjukkan di bawah ini.

local env  = mysql.mysql()
local conn = env:connect('test','root','123456')

Koneksi di atas akan terhubung ke file MySQL yang ada dan membuat koneksi dengan file yang baru dibuat.

Jalankan Fungsi

Ada fungsi eksekusi sederhana yang tersedia dengan koneksi yang akan membantu kita melakukan semua operasi db mulai dari membuat, menyisipkan, menghapus, memperbarui, dan sebagainya. Sintaksnya ditunjukkan di bawah ini -

conn:execute([[ 'MySQLSTATEMENT' ]])

Dalam sintaks di atas, kita perlu memastikan bahwa koneksi terbuka dan koneksi MySQL yang ada dan mengganti 'MySQLSTATEMENT' dengan pernyataan yang benar.

Buat Contoh Tabel

Contoh buat tabel sederhana ditunjukkan di bawah ini. Ini membuat tabel dengan dua id parameter tipe integer dan nama tipe varchar.

mysql = require "luasql.mysql"

local env  = mysql.mysql()
local conn = env:connect('test','root','123456')

print(env,conn)

status,errorString = conn:execute([[CREATE TABLE sample2 (id INTEGER, name TEXT);]])
print(status,errorString )

Saat Anda menjalankan program di atas, akan dibuat tabel bernama sample dengan dua kolom yaitu, id dan name.

MySQL environment (004BB178)	MySQL connection (004BE3C8)
0	nil

Jika ada kesalahan, Anda akan dikembalikan ke pernyataan kesalahan, bukan nil. Pernyataan kesalahan sederhana ditunjukkan di bawah ini.

LuaSQL: Error executing query. MySQL: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '"id INTEGER, name TEXT)' at line 1

Sisipkan Contoh Pernyataan

Pernyataan insert untuk MySQL ditunjukkan di bawah ini.

conn:execute([[INSERT INTO sample values('11','Raj')]])

Perbarui Contoh Pernyataan

Pernyataan pembaruan untuk MySQL ditunjukkan di bawah ini.

conn:execute([[UPDATE sample3 SET name='John' where id ='12']])

Hapus Contoh Pernyataan

Pernyataan delete untuk MySQL ditunjukkan di bawah ini.

conn:execute([[DELETE from sample3 where id ='12']])

Pilih Contoh Pernyataan

Sejauh menyangkut pernyataan pilih, kita perlu melakukan perulangan melalui setiap baris dan mengekstrak data yang diperlukan. Pernyataan pemilihan sederhana ditunjukkan di bawah ini.

cursor,errorString = conn:execute([[select * from sample]])
row = cursor:fetch ({}, "a")

while row do
   print(string.format("Id: %s, Name: %s", row.id, row.name))
   -- reusing the table of results
   row = cursor:fetch (row, "a")
end

Pada kode di atas, conn adalah koneksi MySQL terbuka. Dengan bantuan kursor yang dikembalikan oleh pernyataan eksekusi, Anda dapat mengulang melalui respons tabel dan mengambil data pilihan yang diperlukan.

Contoh Lengkap

Contoh lengkap termasuk semua pernyataan di atas diberikan di bawah ini.

mysql = require "luasql.mysql"

local env  = mysql.mysql()
local conn = env:connect('test','root','123456')
print(env,conn)

status,errorString = conn:execute([[CREATE TABLE sample3 (id INTEGER, name TEXT)]])
print(status,errorString )

status,errorString = conn:execute([[INSERT INTO sample3 values('12','Raj')]])
print(status,errorString )

cursor,errorString = conn:execute([[select * from sample3]])
print(cursor,errorString)

row = cursor:fetch ({}, "a")

while row do
   print(string.format("Id: %s, Name: %s", row.id, row.name))
   row = cursor:fetch (row, "a")
end

-- close everything
cursor:close()
conn:close()
env:close()

Ketika Anda menjalankan program di atas, Anda akan mendapatkan output berikut.

MySQL environment (0037B178)	MySQL connection (0037EBA8)
0	nil
1	nil
MySQL cursor (003778A8)	nil
Id: 12, Name: Raj

Melakukan Transaksi

Transaksi adalah mekanisme yang memastikan konsistensi data. Transaksi harus memiliki empat properti berikut -

  • Atomicity - Entah transaksi selesai atau tidak ada yang terjadi sama sekali.

  • Consistency - Sebuah transaksi harus dimulai dalam keadaan yang konsisten dan membiarkan sistem dalam keadaan yang konsisten.

  • Isolation - Hasil antara transaksi tidak terlihat di luar transaksi saat ini.

  • Durability - Setelah transaksi dilakukan, efeknya tetap ada, bahkan setelah kegagalan sistem.

Transaksi dimulai dengan MULAI TRANSAKSI; dan diakhiri dengan pernyataan komit atau kembalikan.

Mulai Transaksi

Untuk memulai transaksi, kita perlu menjalankan pernyataan berikut di Lua, dengan asumsi conn adalah koneksi MySQL terbuka.

conn:execute([[START TRANSACTION;]])

Transaksi Rollback

Kita perlu mengeksekusi pernyataan berikut untuk mengembalikan perubahan yang dibuat setelah transaksi awal dijalankan.

conn:execute([[ROLLBACK;]])

Lakukan Transaksi

Kita perlu menjalankan pernyataan berikut untuk melakukan perubahan yang dibuat setelah transaksi awal dijalankan.

conn:execute([[COMMIT;]])

Kami telah mengetahui tentang MySQL di atas dan bagian berikut menjelaskan tentang operasi SQL dasar. Ingat transaksi, meskipun tidak dijelaskan lagi untuk SQLite3 tetapi pernyataan yang sama juga harus berfungsi untuk SQLite3.

Mengimpor SQLite

Kita dapat menggunakan pernyataan memerlukan sederhana untuk mengimpor pustaka SQLite dengan asumsi bahwa implementasi Lua Anda telah dilakukan dengan benar. Selama instalasi, folder libsql yang berisi file terkait database.

sqlite3 = require "luasql.sqlite3"

Variabel sqlite3 akan memberikan akses ke fungsi dengan mengacu pada tabel utama sqlite3.

Menyiapkan Koneksi

Kita dapat mengatur koneksi dengan memulai lingkungan SQLite dan kemudian membuat koneksi untuk lingkungan tersebut. Itu ditunjukkan di bawah ini.

local env  = sqlite3.sqlite3()
local conn = env:connect('mydb.sqlite')

Koneksi di atas akan terhubung ke file SQLite yang sudah ada atau membuat file SQLite baru dan membuat koneksi dengan file yang baru dibuat.

Jalankan Fungsi

Ada fungsi eksekusi sederhana yang tersedia dengan koneksi yang akan membantu kita melakukan semua operasi db mulai dari membuat, menyisipkan, menghapus, memperbarui, dan sebagainya. Sintaksnya ditunjukkan di bawah ini -

conn:execute([[ 'SQLite3STATEMENT' ]])

Dalam sintaks di atas kita perlu memastikan bahwa koneksi terbuka dan koneksi sqlite3 ada dan mengganti 'SQLite3STATEMENT' dengan pernyataan yang benar.

Buat Contoh Tabel

Contoh buat tabel sederhana ditunjukkan di bawah ini. Ini membuat tabel dengan dua id parameter tipe integer dan nama tipe varchar.

sqlite3 = require "luasql.sqlite3"

local env  = sqlite3.sqlite3()
local conn = env:connect('mydb.sqlite')
print(env,conn)

status,errorString = conn:execute([[CREATE TABLE sample ('id' INTEGER, 'name' TEXT)]])
print(status,errorString )

Saat Anda menjalankan program di atas, akan dibuat tabel bernama sample dengan dua kolom yaitu, id dan name.

SQLite3 environment (003EC918)	SQLite3 connection (00421F08)
0	nil

Jika terjadi kesalahan, Anda akan dikembalikan ke pernyataan kesalahan, bukan nihil. Pernyataan kesalahan sederhana ditunjukkan di bawah ini.

LuaSQL: unrecognized token: ""'id' INTEGER, 'name' TEXT)"

Sisipkan Contoh Pernyataan

Pernyataan sisipan untuk SQLite ditampilkan di bawah ini.

conn:execute([[INSERT INTO sample values('11','Raj')]])

Pilih Contoh Pernyataan

Sejauh menyangkut pernyataan pilih, kita perlu melakukan perulangan melalui setiap baris dan mengekstrak data yang diperlukan. Pernyataan pemilihan sederhana ditunjukkan di bawah ini.

cursor,errorString = conn:execute([[select * from sample]])
row = cursor:fetch ({}, "a")

while row do
   print(string.format("Id: %s, Name: %s", row.id, row.name))
   -- reusing the table of results
   row = cursor:fetch (row, "a")
end

Dalam kode di atas, conn adalah koneksi sqlite3 terbuka. Dengan bantuan kursor yang dikembalikan oleh pernyataan eksekusi, Anda dapat mengulang melalui respons tabel dan mengambil data pilihan yang diperlukan.

Contoh Lengkap

Contoh lengkap termasuk semua pernyataan di atas diberikan di bawah ini.

sqlite3 = require "luasql.sqlite3"

local env  = sqlite3.sqlite3()
local conn = env:connect('mydb.sqlite')
print(env,conn)

status,errorString = conn:execute([[CREATE TABLE sample ('id' INTEGER, 'name' TEXT)]])
print(status,errorString )

status,errorString = conn:execute([[INSERT INTO sample values('1','Raj')]])
print(status,errorString )

cursor,errorString = conn:execute([[select * from sample]])
print(cursor,errorString)

row = cursor:fetch ({}, "a")

while row do
   print(string.format("Id: %s, Name: %s", row.id, row.name))
   row = cursor:fetch (row, "a")
end

-- close everything
cursor:close()
conn:close()
env:close()

Ketika Anda menjalankan program di atas, Anda akan mendapatkan output berikut.

SQLite3 environment (005EC918)	SQLite3 connection (005E77B0)
0	nil
1	nil
SQLite3 cursor (005E9200)	nil
Id: 1, Name: Raj

Kami dapat mengeksekusi semua kueri yang tersedia dengan bantuan perpustakaan libsql ini. Jadi, tolong jangan berhenti dengan contoh-contoh ini. Lakukan eksperimen berbagai pernyataan kueri yang tersedia di masing-masing MySQL, SQLite3, dan db lain yang didukung di Lua.