HTML5 - Basis Data SQL Web

API Basis Data SQL Web sebenarnya bukan bagian dari spesifikasi HTML5 tetapi merupakan spesifikasi terpisah yang memperkenalkan sekumpulan API untuk memanipulasi basis data sisi klien menggunakan SQL.

Saya berasumsi Anda adalah pengembang web yang hebat dan jika itu masalahnya maka tidak diragukan lagi, Anda akan sangat menyadari konsep SQL dan RDBMS. Jika Anda masih ingin memiliki sesi dengan SQL, Anda dapat melalui Tutorial SQL kami .

Database SQL Web akan berfungsi di versi terbaru Safari, Chrome, dan Opera.

Metode Inti

Ada tiga metode inti berikut yang ditentukan dalam spesifikasi yang akan saya bahas dalam tutorial ini -

  • openDatabase - Metode ini membuat objek database baik menggunakan database yang sudah ada atau membuat yang baru.

  • transaction - Metode ini memberi kita kemampuan untuk mengontrol transaksi dan melakukan commit atau rollback berdasarkan situasinya.

  • executeSql - Metode ini digunakan untuk menjalankan kueri SQL yang sebenarnya.

Membuka Database

The OpenDatabase metode mengurus membuka database jika sudah ada, metode ini akan menciptakan itu jika sudah tidak ada.

Untuk membuat dan membuka database, gunakan kode berikut -

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);

Metode di atas mengambil lima parameter berikut -

  • Nama database
  • Nomor versi
  • Deskripsi teks
  • Ukuran database
  • Panggilan balik pembuatan

Argumen terakhir dan ke-5, pembuatan callback akan dipanggil jika database sedang dibuat. Tanpa fitur ini, bagaimanapun, database masih dibuat dengan cepat dan diversi dengan benar.

Menjalankan kueri

Untuk menjalankan kueri, Anda menggunakan fungsi database.transaction (). Fungsi ini memerlukan satu argumen, yang merupakan fungsi yang menangani eksekusi kueri sebagai berikut:

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024); 

db.transaction(function (tx) {   
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)'); 
});

Kueri di atas akan membuat tabel bernama LOGS di database 'mydb'.

Operasi INSERT

Untuk membuat enteries ke dalam tabel kita menambahkan query SQL sederhana pada contoh di atas sebagai berikut -

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024); 

db.transaction(function (tx) { 
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)'); 
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "foobar")'); 
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")'); 
});

Kita dapat memberikan nilai dinamis sambil membuat masukan sebagai berikut -

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);  

db.transaction(function (tx) {   
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)'); 
   tx.executeSql('INSERT INTO LOGS (id,log) VALUES (?, ?'), [e_id, e_log]; 
});

Sini e_id dan e_log adalah variabel eksternal, dan executeSql memetakan setiap item dalam argumen array ke "?".

BACA Operasi

Untuk membaca record yang sudah ada, kami menggunakan callback untuk menangkap hasil sebagai berikut -

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);  

db.transaction(function (tx) { 
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)');
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "foobar")'); 
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")'); 
});  

db.transaction(function (tx) { 
   tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) { 
      var len = results.rows.length, i; 
      msg = "<p>Found rows: " + len + "</p>"; 
      document.querySelector('#status').innerHTML +=  msg; 
  
      for (i = 0; i < len; i++) { 
         alert(results.rows.item(i).log ); 
      } 
  
   }, null); 
});

Contoh Terakhir

Jadi akhirnya, mari kita simpan contoh ini dalam dokumen HTML5 lengkap sebagai berikut dan coba jalankan dengan browser Safari.

<!DOCTYPE HTML> 

<html>  
   <head> 
  
      <script type = "text/javascript"> 
         var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024); 
         var msg; 
    
         db.transaction(function (tx) { 
            tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)'); 
            tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "foobar")'); 
            tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")'); 
            msg = '<p>Log message created and row inserted.</p>'; 
            document.querySelector('#status').innerHTML =  msg; 
         })

         db.transaction(function (tx) { 
            tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) { 
               var len = results.rows.length, i; 
               msg = "<p>Found rows: " + len + "</p>"; 
               document.querySelector('#status').innerHTML +=  msg; 
      
               for (i = 0; i < len; i++) { 
                  msg = "<p><b>" + results.rows.item(i).log + "</b></p>"; 
                  document.querySelector('#status').innerHTML +=  msg; 
               } 
            }, null); 
         }); 
      </script> 
   </head> 
  
   <body> 
      <div id = "status" name = "status">Status Message</div> 
   </body> 
</html>

Ini akan menghasilkan hasil sebagai berikut -