SQLite是一個簡易的資料庫系統,開放原始碼,可以直接把SQLite綁在程式裡使用,FireFox及Android等軟體也都有內建SQLite。SQLite不需要安裝,看起來就只是一個檔案而已,也可以使用memory模式,讓它存在記憶體中而不需要建立一個檔案存放。
SQLite支援的SQL指令:http://www.sqlite.org/lang_corefunc.html
C#要連接SQLite可以使用open source的System.Data.SQLite,它是一個基於ADO.Net所做與SQLite的溝通介面,目前支援到.net framework 3.5。可於sourceforge下載其dll來使用,就可以了。
下方的範例是介紹如何在Csharp下使用ADO.NET連接與操作SQLite,包含了自動產生SQLite檔案與DataGridView使用class binding datasource方法。
一、建立一個專案,並先將其儲存起來
(需要先建置專案才能使用專案裡的class當做datasource)
data:image/s3,"s3://crabby-images/2d859/2d85967abd1168d481a41456b35561decb4a46fd" alt="01.jpg"
data:image/s3,"s3://crabby-images/1cdc1/1cdc1bf055f0a44a59eeb930a1600b7368667b90" alt="02.jpg"
二、改變專案使用的Framework
在專案節點上選擇屬性
data:image/s3,"s3://crabby-images/f4268/f4268141dee576e380cebd72231de6710219b309" alt="專案屬性"
把目標Framework(G):改成.NET Framework 3.5以下
data:image/s3,"s3://crabby-images/1125a/1125aa06e0ad5fb95970dc8bac39b7ab6511ffe6" alt="Csharp屬性視窗"
告知需要重新啟動專案
data:image/s3,"s3://crabby-images/0992a/0992af6b76e69304157f340afc4dfb3ee137d391" alt="告知需要重新啟動專案"
三、加入System.Data.SQLite的Dll當做參考
在專案裡的參考節點上按右鍵選加入參考(R)….
data:image/s3,"s3://crabby-images/08c8b/08c8b879d426f76a3b4507b05db9ec964ca4daa7" alt="06.jpg"
找到DLL加入
data:image/s3,"s3://crabby-images/44820/44820898e382117362de2a3e441bf13873a72969" alt="System.Data.SQLite.dll"
在參考的節點上可以看到System.Data.SQLite已加入成功
因為原本專案為.NET Framework 4被降為3.5,所以會多出一個無法使用的參考Microsoft CSharp,此時可順便移除掉它。
data:image/s3,"s3://crabby-images/7265e/7265e8edc6fc400a1afe70ed235cf870478ca56a" alt="Microsoft CSharp"
四、建立相容模式
SQLite ADO.NET是建立於版本v2.0.50727,所以在比較高的版本會有相容性問題,所以修改app.config或web.config來使其相容使用。
ps.有一說可以在.NET Framework 4.0修改設定則可以使用SQLite ADO.NET
data:image/s3,"s3://crabby-images/e5b0e/e5b0eb1c24bb3a8f69b5988b968b8fdf96bc4bcb" alt="app.config"
在startup的tag上加上屬性
<startup useLegacyV2RuntimeActivationPolicy="true"> <supportedRuntime version="v2.0.50727"/> </startup>
在範列裡我們會使用到二種建立SQLite Connection的方法,其中一種為DbProvider,所以需要使用到以下tag內容,放在configuration內就可以了,如果不使用此種DbProvider方法,也可不加。
<system.data> <DbProviderFactories> <remove invariant="System.Data.SQLite"/> <add name="SQLite Data Provider" invariant="System.Data.SQLite" description=".Net Framework Data Provider for SQLite" type="System.Data.SQLite.SQLiteFactory, System.Data.SQLite"/> </DbProviderFactories> </system.data>
data:image/s3,"s3://crabby-images/c5519/c551948b305417ffb4e4ad80bdadc660f3874f76" alt="app.config useLegacyV2RuntimeActivationPolicy"
五、建立取得Connection的程式與需要使用的class
data:image/s3,"s3://crabby-images/3fad5/3fad5a621c801dd654f862b55c4a5bc14e075e5f" alt="建立Class"
Db.css
以下是使用DbOroviderFactory的方法建立Connection
private static DbProviderFactory fact = DbProviderFactories.GetFactory("System.Data.SQLite"); public static DbConnection getConnection()
以下是直接使用new SQLiteConnection來建立連線
public static SQLiteConnection getConnection2()
使用以下語法可以建立SQLite檔案
SQLiteConnection.CreateFile("db/db.s3db");
SQLite在使用時它的ConnectionString “db/db.s3db”,db為其目錄,而db.s3db為其檔案名稱。
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data.Common; using System.Data.SQLite; using System.IO; namespace SQLiteCon { class Db { private static DbProviderFactory fact = DbProviderFactories.GetFactory("System.Data.SQLite"); public static DbConnection getConnection() { if (!Directory.Exists("db")) { Directory.CreateDirectory("db"); } //檔案不存在時就建立 if (!File.Exists("db/db.s3db")) { //自動建立SQLite檔案 SQLiteConnection.CreateFile("db/db.s3db"); } DbConnection cnn = fact.CreateConnection(); cnn.ConnectionString = "Data Source=db/db.s3db"; return cnn; } public static SQLiteConnection getConnection2() { if (!Directory.Exists("db")) { Directory.CreateDirectory("db"); } if (!File.Exists("db/db.s3db")) SQLiteConnection.CreateFile("db/db.s3db"); return new SQLiteConnection("Data Source=db/db.s3db"); } } }
Class1.cs
提供一個class專門來承載資料內容mytest
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data.SQLite; using System.Data.Common; namespace SQLiteCon { //使用SQLiteConnection public class mytestnList2 { //利用資料庫查詢把內容查出後存到List的泛型裡 public List<mytest> getAllList() { List<mytest> list = new List<mytest>(); SQLiteConnection conn = Db.getConnection2(); conn.Open(); try { String sql = "select * from mytest"; SQLiteCommand com = conn.CreateCommand(); com.CommandText = sql; SQLiteDataReader reader = com.ExecuteReader(); while (reader.Read()) { mytest idc = new mytest(); idc.item_id = reader.GetString(0); idc.item_name = reader.GetString(1); list.Add(idc); } } catch (Exception ex) { Console.WriteLine(ex); } finally { conn.Close(); } return list; } } //使用DbConnection public class mytestnList { //利用資料庫查詢把內容查出後存到List的泛型裡 public List<mytest> getAllList() { List<mytest> list = new List<mytest>(); DbConnection conn = Db.getConnection(); conn.Open(); try { String sql = "select * from mytest"; DbCommand com = conn.CreateCommand(); com.CommandText = sql; DbDataReader reader = com.ExecuteReader(); while (reader.Read()) { mytest idc = new mytest(); idc.item_id = reader.GetString(0); idc.item_name = reader.GetString(1); list.Add(idc); } } catch (Exception ex) { Console.WriteLine(ex); } finally { conn.Close(); } return list; } } //資料型態與名稱 public class mytest { public String item_id { set; get; } public String item_name { set; get; } } }
六、建立顯示及操作畫面
data:image/s3,"s3://crabby-images/6b8c4/6b8c481397338622e3883c9432dd9eb659f81db8" alt="SQLite操作畫面"
把DataGridView的DataSource綁定到bindingSource,二組各自綁定一個bindingSource
data:image/s3,"s3://crabby-images/9c310/9c3104e9c2ed8b531367535f8e1decb9c2df2c26" alt="DataGridView binding DataSource"
建置方案,如此class才會被編譯成dll,在使用資料組態來源精靈時才可以看到
data:image/s3,"s3://crabby-images/80415/80415a765d43707623ba475197b6ef12c97e8d9f" alt="Compiler"
把二組的bindingSource都設定其DataSource,利用加入專案資料來源來建立
data:image/s3,"s3://crabby-images/01d22/01d22d6bc9f7b30052e3a97dc9d51f07ad1fb5e7" alt="bindingSource Bind class datasource"
類型選擇”物件”
data:image/s3,"s3://crabby-images/81332/81332cc0658148632b887e957eb955674892a408" alt="17.jpg"
然後選擇先寫好的class myetest
data:image/s3,"s3://crabby-images/ba22c/ba22cb55dc50883b111d28491b8d63c065161a1c" alt="18.jpg"
data:image/s3,"s3://crabby-images/ca174/ca1749cbaa71e88e947ff441c015d5a52489bb68" alt="19.jpg"
另一組則可直接選取,不需要再使用精靈
data:image/s3,"s3://crabby-images/9a917/9a917c397fb4eb2e19ff2a0ed92212d2a071fc99" alt="20.jpg"
畫面已經顯示clas裡所定義的欄位,可以自行修改header的名稱來對應
data:image/s3,"s3://crabby-images/91fbf/91fbfde1f0bf1507e463bb04495b1c57aa00569b" alt="畫面配置"
再來針對四個button建立click event的程式
//移除table private void button1_Click(object sender, EventArgs e) { try { using (DbConnection con = Db.getConnection()) { con.Open(); DbCommand cmd = con.CreateCommand(); cmd.CommandText = "drop table mytest"; cmd.ExecuteNonQuery(); con.Close(); } } catch (SQLiteException) { }; } //建立table private void button2_Click(object sender, EventArgs e) { try { using (DbConnection con = Db.getConnection()) { con.Open(); DbCommand cmd = con.CreateCommand(); cmd.CommandText = "create table mytest(item_id TEXT,item_name TEXT);"; cmd.ExecuteNonQuery(); con.Close(); } } catch (SQLiteException) { }; } //新增二筆資料,當測試 private void button3_Click(object sender, EventArgs e) { try { using (DbConnection con = Db.getConnection()) { con.Open(); DbCommand cmd = con.CreateCommand(); cmd.CommandText = "insert into mytest(item_id ,item_name ) values('111','中文');"; cmd.ExecuteNonQuery(); cmd.CommandText = "insert into mytest(item_id ,item_name ) values('222','abc');"; cmd.ExecuteNonQuery(); con.Close(); } } catch (SQLiteException) { }; } //載入資料到DataSource,則form的GridView就可以看到資料了 private void button4_Click(object sender, EventArgs e) { List<mytest> list = (new mytestnList()).getAllList(); bindingSource1.DataSource = list; List<mytest> list2 = (new mytestnList2()).getAllList(); bindingSource2.DataSource = list2; }
七、執行結果
原本在目錄裡並沒有db/db.s3db的目錄及檔案
data:image/s3,"s3://crabby-images/0780f/0780f63b574945707a54cf0f953c30d87d255fa5" alt="22.jpg"
由上而下操作後,可以看到GridView裡有了二筆資料
data:image/s3,"s3://crabby-images/756e2/756e2aab6a5285ca8a93eba52249ea230a67ccf5" alt="SQLite執行結果"
再查看目錄裡已經自動建立SQLite的檔案了
data:image/s3,"s3://crabby-images/2ccb7/2ccb7686388c6012e3be08cb197399dcb62024ae" alt="24.jpg"
One thought to “Csharp使用ADO.NET操作SQLite”