विंडोज 10 डेवलपमेंट - SQLite डेटाबेस

कई अनुप्रयोगों में, कुछ प्रकार के डेटा होते हैं, जिनका एक दूसरे से किसी प्रकार का संबंध होता है। इस प्रकार के डेटा, जो एक फ़ाइल में स्टोर करना मुश्किल है, एक डेटाबेस में संग्रहीत किया जा सकता है।

यदि आप किसी भी एप्लिकेशन में SQL सर्वर या Oracle डेटाबेस जैसे डेटाबेस से परिचित हैं, तो यह समझना बहुत आसान है SQLite database

SQLite क्या है?

SQLite एक सॉफ्टवेयर लाइब्रेरी है जो एक आत्म निहित, सर्वर कम, शून्य-कॉन्फ़िगरेशन, ट्रांसेक्शनल SQL डेटाबेस इंजन को लागू करता है।

महत्वपूर्ण विशेषताएं हैं -

  • SQLite दुनिया में सबसे व्यापक रूप से तैनात डेटाबेस इंजन है।

  • SQLite के लिए स्रोत कोड खुला स्रोत है।

  • पोर्टेबिलिटी और छोटे पदचिह्न के कारण खेल और मोबाइल एप्लिकेशन विकास पर इसका बड़ा प्रभाव पड़ा है।

SQLite के लाभ

SQLite के फायदे निम्नलिखित हैं -

  • यह बहुत हल्का डेटाबेस है।
  • यह प्लेटफॉर्म स्वतंत्र है और सभी प्लेटफार्मों पर काम करता है।
  • इसमें एक छोटा मेमोरी फुटप्रिंट है।
  • यह विश्वसनीय है।
  • किसी भी सेटअप और स्थापना के लिए कोई ज़रूरत नहीं है।
  • इसकी कोई निर्भरता नहीं है।

काम में लाना SQLite अपने यूनिवर्सल विंडोज प्लेटफ़ॉर्म (UWP) अनुप्रयोगों में, आपको नीचे दिए गए चरणों का पालन करने की आवश्यकता है।

  • नाम के साथ एक नया यूनिवर्सल विंडोज खाली ऐप बनाएं UWPSQLiteDemo

  • के पास जाओ Toolsमेनू और एक्सटेंशन और अपडेट का चयन करें। निम्नलिखित संवाद खुल जाएगा।

  • एक्सटेंशन और अपडेट का चयन करने के बाद, निम्न विंडो खुल जाएगी।
  • अब का चयन करें Online विकल्प और बाएँ फलक से SQLite के लिए खोजें।

  • यूनिवर्सल ऐप प्लेटफ़ॉर्म के लिए SQLite डाउनलोड और इंस्टॉल करें।

  • अब, टूल मेनू पर फिर से जाएं और चुनें NuGet Package Manager > Package Manager Console मेनू विकल्प जैसा कि नीचे दिखाया गया है।

  • पैकेज मैनेजर कंसोल में निम्नलिखित कमांड लिखें और इस कमांड को निष्पादित करने के लिए एंटर दबाएं -

Install-Package SQLite.Net-PCL
  • अब राईट क्लिक करे References समाधान एक्सप्लोरर में और चुनें Add References

  • निम्नलिखित संवाद खुल जाएगा।
  • चुनते हैं Extensions के नीचे बाएँ फलक से Universal Windows, यूनिवर्सल फलक में यूनिवर्सल ऐप प्लेटफ़ॉर्म के लिए SQLite की जाँच करें, और ओके पर क्लिक करें।

  • अब आप अपने UWP अनुप्रयोगों में SQLite पर जाने और उसका उपयोग करने के लिए तैयार हैं।

आप निम्न कोड का उपयोग करके एक डेटाबेस बना सकते हैं।

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);

एक तालिका बनाने के लिए आपको कॉल करने की आवश्यकता है CreateTable तालिका नाम ऑब्जेक्ट के साथ विधि।

conn.CreateTable<Customer>();

आप निम्न कोड का उपयोग करके डेटा को अपनी तालिका में सम्मिलित कर सकते हैं।

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

नीचे दी गई तालिका से डेटा पुनर्प्राप्त करने के लिए कोड है।

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; 
}

आइए हम समझते हैं कि एक डेटाबेस, एक तालिका कैसे बनाएं और एक साधारण उदाहरण की मदद से डेटाबेस से डेटा कैसे डालें और पुनर्प्राप्त करें। हम नाम और आयु जोड़ते जाएंगे और फिर हम तालिका से समान डेटा प्राप्त करेंगे। नीचे दिया गया XAML कोड है जिसमें विभिन्न नियंत्रण जोड़े जाते हैं।

<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>

नीचे दिए गए घटनाओं के लिए C # कार्यान्वयन है और 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; } 
   } 
	
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।

प्रवेश करें Name तथा Age और क्लिक करें Add बटन।

अब पर क्लिक करें Retrieveबटन। आप निम्न डेटा को देखेंगेText Block

आईडी फ़ील्ड एक प्राथमिक कुंजी और ऑटो इंक्रीमेंट फ़ील्ड है, जो ग्राहक वर्ग में निर्दिष्ट है।

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