NLite.Data的应用
前段時間,我們對NLite.Data進行了開發,其NLite.Data Framework 是一個輕量簡單易用的開源Linq ORM數據訪問組件,支持Nullable類型和枚舉類型,對Linq的謂詞提供了完美的支持,旨在讓絕大部份的主流數據庫都使用 Linq 來進行程序開發,讓開發人員訪問數據庫從SQL中解放出來,易學易用上手快,配置簡單,并且提供了源代碼下載,方便定制。支持多數據庫,目前支持Access、SQLServer、SqlCE、SQLite、MySQL、ORACLE,未來還會支持更多的數據庫。現在進度將近尾聲,下面我對此組件的使用方法和步驟做下說明:
?????
????? 1.? 安裝NLite Linq ORM Framework?
? 在Package Manager Console控制臺中輸入下列命令:
? PM> Install-Package NLite.Data?
備注:Nuget安裝方法和步驟:? http://docs.nuget.org/docs/start-here/installing-nuget
Nuget使用說明:??http://docs.nuget.org/docs/start-here/using-the-package-manager-console
2.??連接字符串配置
? 在配置文件中配置連接數據庫字符串,以Sql Server Compact 為例
<configuration><connectionStrings><add providerName="System.Data.SqlServerCe.3.5" name ="Demo" connectionString="Data Source=DataBase\MyDatabase#1.sdf;Persist Security Info=True;pwd = 123"/></connectionStrings></configuration>?
3.? 數據庫表設計
?列名????????? 數據類型????????? 長度????????? 允許空值???????????是否自增???????? 主鍵
?ID???????????? int??????????????????4???????????????? 否??????????????????是??????????? 是
Name??????? nvarchar?????????10??????????????? 否????????????????? 否??????????? 否
Gender????? real?????????????????4???????????????? 是????????????????? 否????????????否
?Age???????????int??????????????????4???????????????? 是??????????????????否??????????? 否
?
?? 4.??實體類的配置
????????? 首先引用NLite.Data.dll組件,然后添加屬性(這里必須為屬性,不可為字段),實體類中的屬性要與數據庫表中的列相對應。下面舉例說明,我在數據庫中建了一個名為User的表,包含ID、Name、Gender、Age列。那么,在實體類中的配置如下:
??????????標準配置:
1 [Table(Name = "User")] 2 public class User 3 { 4 [Id(IsDbGenerated = true)] 5 public int ID { get; set; } 6 [Column(Name = "Name")] 7 public string Name { get; set; } 8 [Column(Name = "Gender")] 9 public bool Gender { get; set; } 10 [Column(Name = "Age")] 11 public int Age { get; set; } 12 }???????? 缺省配置:
1 public class User 2 { 3 public int ID { get; set; } 4 public string Name { get; set; } 5 public bool Gender { get; set; } 6 public int Age { get; set; } 7 }說明:如果其他屬性名或類名與數據庫表中的列名或表名一致,則實體類中相應的屬性或類名上面可以不寫標志,可以直接映射。不清楚可以參考:http://ndo.codeplex.com/?下的“設計理念”
5.? 寫Sql語句之前的配置
寫Sql語句之前還需要配置,以上面的User表為例:
1 connectionStringName = "Demo"; 2 cfg = DbConfiguration 3 .Configure(connectionStringName)//通過connectionStringName對象創建DbConfiguration對象(可以用于配置文件中有多個數據庫連接字符串配置) 4 .AddClass<Model.User>()//注冊實體到數據表的映射關系 5 ;?
6.??增、刪、改、查代碼示例?
- ?添加用戶示例
?語句描述:實例化一個Use對象(ID為自增,可不寫),是以對象的形式插入到數據庫中,Insert方法返回一個整型值,成功為1,否則為0。
注:該語句生成的sql語句為:
1 INSERT INTO [User] ( [Name], [Gender],[Age] ) 2 VALUES (@p0, 1 , 23) 3 -- p0:(DbType = String,Value = 新記錄)- 刪除用戶示例
語句描述:該方法是通過唯一標識ID刪除數據庫中的一條記錄,Delete方法返回一個整型值,成功為1,否則為0。
?注:該語句生成的sql語句為:
1 DELETE FROM [User] 2 WhERE ( [ID] = 5 )- 修改用戶示例
語句描述:實例化一個Use對象(其中包含唯一的標識),是以對象的形式通過唯一標識找到該記錄并更新數據庫表中的記錄,Update方法返回一個整型值,成功為1,否則為0。
? 注:該語句生成的sql語句為: ?
1 UPDATE [User] 2 SET [Name] = @p0, [Gender] = 0, [Age] = 24 3 WHERE ( [ID] = 5 ) 4 -- p0:( DbType = String,Value = 修改新記錄 )- 查詢用戶示例
語句描述:第一條語句是查詢表中所有的記錄,存儲到User[]數組里面; 第二條語句查詢ID為5的記錄。
注:語句生成的sql語句分別為:?
1 SELECT t0.[ID], t0.[Name], t0.[Gender], t0.[Age] 2 FROM [User] AS t0 3 --查詢表中所有的記錄 4 5 SELECT t0.[ID], t0.[Name], t0.[Gender], t0.[Age] 6 FROM [User] AS t0 7 WHERE ( t0.[ID] = 5 ) 8 --查詢ID為5的這條記錄?
?????? 示例源代碼下載:http://files.cnblogs.com/xiaocaibaodao/Demo.rar?
?????? 關系查詢Demo下載:http://files.cnblogs.com/xiaocaibaodao/Demo1.rar
轉載于:https://www.cnblogs.com/xiaocaibaodao/archive/2012/11/20/2778659.html
總結
以上是生活随笔為你收集整理的NLite.Data的应用的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用万能头文件 #include<bit
- 下一篇: cva《财务建模》第五讲笔记