विंडोज 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; }