Pengembangan Windows 10 - Database SQLite

Dalam banyak aplikasi, terdapat tipe data tertentu, yang memiliki semacam hubungan satu sama lain. Jenis data ini, yang sulit untuk disimpan dalam sebuah file, dapat disimpan dalam database.

Jika Anda terbiasa dengan jenis database, seperti SQL server atau database Oracle di aplikasi apa pun, maka sangat mudah untuk dipahami. SQLite database.

Apa itu SQLite?

SQLite adalah pustaka perangkat lunak yang mengimplementasikan mesin database SQL transaksional, tanpa server, tanpa konfigurasi, dan mandiri.

Fitur penting adalah -

  • SQLite adalah mesin database yang paling banyak digunakan di dunia.

  • Kode sumber untuk SQLite adalah Open source.

  • Ini berdampak besar pada pengembangan game dan aplikasi seluler, karena portabilitas dan footprint yang kecil.

Keuntungan SQLite

Berikut ini adalah keunggulan SQLite -

  • Ini adalah database yang sangat ringan.
  • Ini adalah platform independen dan berfungsi di semua platform.
  • Ini memiliki jejak memori yang kecil.
  • Itu bisa diandalkan.
  • Tidak perlu penyiapan dan penginstalan apa pun.
  • Ini tidak memiliki ketergantungan.

Menggunakan SQLite di aplikasi Universal Windows Platform (UWP) Anda, Anda perlu mengikuti langkah-langkah yang diberikan di bawah ini.

  • Buat aplikasi kosong Universal Windows baru dengan nama UWPSQLiteDemo.

  • Pergi ke Toolsmenu dan pilih Ekstensi dan Pembaruan. Dialog berikut akan terbuka.

  • Setelah memilih Extensions and Updates, jendela berikut akan terbuka.
  • Sekarang pilih Online opsi dan cari SQLite, dari panel kiri.

  • Unduh dan Instal SQLite untuk Platform Aplikasi Universal.

  • Sekarang, masuk ke menu Tools lagi dan pilih NuGet Package Manager > Package Manager Console pilihan menu seperti yang ditunjukkan di bawah ini.

  • Tulis perintah berikut di Package Manager Console dan tekan enter untuk menjalankan perintah ini -

Install-Package SQLite.Net-PCL
  • Sekarang klik kanan References di penelusur solusi dan pilih Add References.

  • Dialog berikut akan terbuka.
  • Pilih Extensions dari panel kiri di bawah Universal Windows, periksa SQLite untuk Platform Aplikasi Universal di panel tengah, dan klik Ok.

  • Sekarang Anda siap untuk pergi dan menggunakan SQLite di aplikasi UWP Anda.

Anda dapat membuat database dengan menggunakan kode berikut ini.

string path = Path.Combine(Windows.Storage.ApplicationData.
   Current.LocalFolder.Path, "db.sqlite"); 

SQLite.Net.SQLiteConnection conn = new SQLite.Net.SQLiteConnection(new 
   SQLite.Net.Platform.WinRT.SQLitePlatformWinRT(), path);

Untuk membuat tabel, Anda perlu menelepon CreateTable metode dengan objek nama tabel.

conn.CreateTable<Customer>();

Anda dapat memasukkan data ke dalam tabel Anda dengan menggunakan kode berikut.

conn.Insert(new Customer(){
   Name = textBox.Text, 
   Age = textBox1.Text 
});

Diberikan di bawah ini adalah kode untuk mengambil data dari tabel.

var query = conn.Table<Customer>(); 
string id = ""; 
string name = ""; 
string age = ""; 
 
foreach (var message in query) { 
   id = id + " " + message.Id; 
   name = name + " " + message.Name; 
   age = age + " " + message.Age; 
}

Mari kita pahami cara membuat database, tabel dan cara memasukkan dan mengambil data dari database dengan bantuan contoh sederhana. Kami akan menambahkan Nama dan usia dan kemudian kami akan mengambil data yang sama dari tabel. Diberikan di bawah ini adalah kode XAML di mana kontrol yang berbeda ditambahkan.

<Page 
   x:Class = "UWPSQLiteDemo.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:local = "using:UWPSQLiteDemo" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   mc:Ignorable = "d"> 
	
   <Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}" >
      <Button x:Name = "Retrieve" Content = "Retrieve" HorizontalAlignment = "Left"  
         VerticalAlignment = "Top" Margin = "384,406,0,0"  
         Click = "Retrieve_Click"/>
			
      <Button x:Name = "Add" Content = "Add" HorizontalAlignment = "Left"  
         VerticalAlignment = "Top" Margin = "291,406,0,0" Click = "Add_Click"/>
			
      <TextBlock x:Name = "textBlock" HorizontalAlignment = "Left"  
         TextWrapping = "Wrap" Text = "Name" VerticalAlignment = "Top"  
         Margin = "233,280,0,0" Width = "52"/>
			
      <TextBox x:Name = "textBox" HorizontalAlignment = "Left" TextWrapping = "Wrap"  
         VerticalAlignment = "Top" Margin = "289,274,0,0" Width = "370"/>
			
      <TextBlock x:Name = "textBlock1" HorizontalAlignment = "Left"  
         TextWrapping = "Wrap" Text = "Age" VerticalAlignment = "Top"  
         Margin = "233,342,0,0" Width = "52"/>
			
      <TextBox x:Name = "textBox1" HorizontalAlignment = "Left" TextWrapping = "Wrap"  
         VerticalAlignment = "Top" Margin = "289,336,0,0" Width = "191"/>
			
      <TextBlock x:Name = "textBlock2" HorizontalAlignment = "Left"  
         Margin = "290,468,0,0" TextWrapping = "Wrap"  
         VerticalAlignment = "Top" Width = "324" Height = "131"/>
			
   </Grid>
	
</Page>

Diberikan di bawah ini adalah implementasi C # untuk acara dan SQLite database.

using SQLite.Net.Attributes; 

using System; 
using System.Collections.Generic; 
using System.IO; 
using System.Linq; 
using System.Runtime.InteropServices.WindowsRuntime; 

using Windows.Foundation; 
using Windows.Foundation.Collections; 

using Windows.UI.Xaml; 
using Windows.UI.Xaml.Controls; 
using Windows.UI.Xaml.Controls.Primitives; 
using Windows.UI.Xaml.Data; 
using Windows.UI.Xaml.Input; 
using Windows.UI.Xaml.Media; 
using Windows.UI.Xaml.Navigation;  

// The Blank Page item template is documented at 
   http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409 
 
namespace UWPSQLiteDemo {
 
   /// <summary>
      /// An empty page that can be used on its own or navigated to within a Frame.
   /// </summary>
	
   public sealed partial class MainPage : Page {
      string path; 
      SQLite.Net.SQLiteConnection conn; 
		
      public MainPage(){
         this.InitializeComponent();  
         path = Path.Combine(Windows.Storage.ApplicationData.Current.LocalFolder.Path,
            "db.sqlite"); 
         conn = new SQLite.Net.SQLiteConnection(new 
            SQLite.Net.Platform.WinRT.SQLitePlatformWinRT(), path);  
         conn.CreateTable<Customer>(); 
      }
		
      private void Retrieve_Click(object sender, RoutedEventArgs e) { 
         var query = conn.Table<Customer>(); 
         string id = ""; 
         string name = ""; 
         string age = "";  
			
         foreach (var message in query) {
            id = id + " " + message.Id; 
            name = name + " " + message.Name; 
            age = age + " " + message.Age; 
         }
			
         textBlock2.Text = "ID: " + id + "\nName: " + name + "\nAge: " + age; 
      }  
		
      private void Add_Click(object sender, RoutedEventArgs e){ 
       
         var s = conn.Insert(new Customer(){
            Name = textBox.Text, 
            Age = textBox1.Text 
         }); 
			
      } 
   } 
	
   public class Customer {
      [PrimaryKey, AutoIncrement] 
      public int Id { get; set; } 
      public string Name { get; set; } 
      public string Age { get; set; } 
   } 
	
}

Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut.

Masukkan Name dan Age dan klik Add tombol.

Sekarang klik pada Retrievetombol. Anda akan melihat data berikut diText Block.

Bidang ID adalah bidang Kunci Utama dan Kenaikan Otomatis, yang ditentukan di kelas Pelanggan.

[PrimaryKey, AutoIncrement] 
public int Id { get; set; }