SQLite簡易版ORM
首先開啟專案,使用nuget搜尋sqlite-net,如下圖:
下載完成後,我們會多出兩個檔案,SQLite.cs和SQLiteAsync.cs。
我們新建一個資料夾SQLiteResources,把這倆檔案放進去。
然後我們建立兩個表實體,如下:
public class Valuation { [PrimaryKey, AutoIncrement] public int Id { get; set; } [Indexed("ValuationStockId2",1)] //索引,注意,該索引在表建立時,會建立,如果索引改名,舊索引依然存在,並未被刪除 public int StockId { get; set; } public DateTime Time { get; set; } public decimal Price { get; set; } } public class Stock { [PrimaryKey, AutoIncrement] public int Id { get; set; } public string Symbol { get; set; } }
接下來我們建立一個SQLiteHelper,用來管理Sqlite資料庫,如下:
public class SQLiteHelper { public string connstr = Path.Combine(Environment.CurrentDirectory, "User.db");//沒有資料庫會建立資料庫 public SQLiteConnection db; public SQLiteHelper() { db = new SQLiteConnection(connstr); db.CreateTable<Stock>();//表已存在不會重複建立 db.CreateTable<Valuation>(); } public int Add<T>(T model) { return db.Insert(model); } public int Update<T>(T model) { return db.Update(model); } public int Delete<T>(T model) { return db.Update(model); } public List<T> Query<T>(string sql) where T : new() { return db.Query<T>(sql); } public int Execute(string sql) { return db.Execute(sql); } }
到此,我們的簡易版ORM就搭建好了,下面讓我們一起試用下這個ORM。
首先我們新增一個專案,SqliteTestConsole。
然後在Main函式中寫上測試程式碼如下:
static void Main(string[] args) { SQLiteHelper sqliteHelper = new SQLiteHelper(); var list = sqliteHelper.Query<Stock>("select * from Stock"); sqliteHelper.Add(new Valuation() { Price = 100, StockId = 1, Time = DateTime.Now }); var list2 = sqliteHelper.Query<Valuation>("select * from Valuation"); var list3 = sqliteHelper.Query<Valuation>("select * from Valuation INDEXED BY ValuationStockId2 WHERE StockId > 2");//使用索引ValuationStockId2查詢 try { sqliteHelper.Execute("drop index ValuationStockId");//刪除索引,因為該索引已被刪除,所以拋異常 } catch (Exception ex) { } }
然後執行除錯,會丟擲異常如下:
那麼我們到底缺少什麼依賴檔案呢?
開啟SQLite.cs檔案,我們會發現如下程式碼:
如上圖所示,我們缺少了依賴dll—sqlite3.dll。
下面我們開啟sqlite的官網尋找並下載依賴動態庫【Sqlite官網下載網址】
因為專案使用x86的Framework4.6.1,所以我們要找到對應的sqlite版本。
下載完成後,我們可看到如下檔案。
我們把其中的sqlite3.dll移動到專案的輸出目錄【X盤\SqliteTestConsole\bin\Debug】下面。
然後我們執行專案,專案依然提示錯誤。
這是因為我們的下載的sqllite3.dll是x86的版本,所以我們要把Any CPU修改為x86,選擇【配置管理器】,如下圖:
然後我們再執行測試專案就可以正常編譯通過了。
現在,我們再使用sqlitebrowser開啟我們建立的User.db檢視資料。
sqlitebrowser是一個sqlite的開源管理工具,下載地址:https://github.com/sqlitebrowser/sqlitebrowser。
如圖所示,我們已經成功建立了表,並完成了插入資料操作。
----------------------------------------------------------------------------------------------------
到此SQLite的簡易ORM就已經搭建完成了。
程式碼已經傳到Github上了,歡迎大家下載。
Github地址:https://github.com/kiba518/SQLite_net.Helper
----------------------------------------------------------------------------------------------------
注:此文章為原創,歡迎轉載,請在文章頁面明顯位置給出此文連結!
若您覺得這篇文章還不錯,請點選下方的【推薦】,非常感謝!