NLite.Data的应用
前段時(shí)間,我們對(duì)NLite.Data進(jìn)行了開發(fā),其NLite.Data Framework 是一個(gè)輕量簡(jiǎn)單易用的開源Linq ORM數(shù)據(jù)訪問組件,支持Nullable類型和枚舉類型,對(duì)Linq的謂詞提供了完美的支持,旨在讓絕大部份的主流數(shù)據(jù)庫(kù)都使用 Linq 來進(jìn)行程序開發(fā),讓開發(fā)人員訪問數(shù)據(jù)庫(kù)從SQL中解放出來,易學(xué)易用上手快,配置簡(jiǎn)單,并且提供了源代碼下載,方便定制。支持多數(shù)據(jù)庫(kù),目前支持Access、SQLServer、SqlCE、SQLite、MySQL、ORACLE,未來還會(huì)支持更多的數(shù)據(jù)庫(kù)?,F(xiàn)在進(jìn)度將近尾聲,下面我對(duì)此組件的使用方法和步驟做下說明:
?????
????? 1.? 安裝NLite Linq ORM Framework?
? 在Package Manager Console控制臺(tái)中輸入下列命令:
? 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.??連接字符串配置
? 在配置文件中配置連接數(shù)據(jù)庫(kù)字符串,以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.? 數(shù)據(jù)庫(kù)表設(shè)計(jì)
?列名????????? 數(shù)據(jù)類型????????? 長(zhǎng)度????????? 允許空值???????????是否自增???????? 主鍵
?ID???????????? int??????????????????4???????????????? 否??????????????????是??????????? 是
Name??????? nvarchar?????????10??????????????? 否????????????????? 否??????????? 否
Gender????? real?????????????????4???????????????? 是????????????????? 否????????????否
?Age???????????int??????????????????4???????????????? 是??????????????????否??????????? 否
?
?? 4.??實(shí)體類的配置
????????? 首先引用NLite.Data.dll組件,然后添加屬性(這里必須為屬性,不可為字段),實(shí)體類中的屬性要與數(shù)據(jù)庫(kù)表中的列相對(duì)應(yīng)。下面舉例說明,我在數(shù)據(jù)庫(kù)中建了一個(gè)名為User的表,包含ID、Name、Gender、Age列。那么,在實(shí)體類中的配置如下:
??????????標(biāo)準(zhǔn)配置:
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 }說明:如果其他屬性名或類名與數(shù)據(jù)庫(kù)表中的列名或表名一致,則實(shí)體類中相應(yīng)的屬性或類名上面可以不寫標(biāo)志,可以直接映射。不清楚可以參考:http://ndo.codeplex.com/?下的“設(shè)計(jì)理念”
5.? 寫Sql語(yǔ)句之前的配置
寫Sql語(yǔ)句之前還需要配置,以上面的User表為例:
1 connectionStringName = "Demo"; 2 cfg = DbConfiguration 3 .Configure(connectionStringName)//通過connectionStringName對(duì)象創(chuàng)建DbConfiguration對(duì)象(可以用于配置文件中有多個(gè)數(shù)據(jù)庫(kù)連接字符串配置) 4 .AddClass<Model.User>()//注冊(cè)實(shí)體到數(shù)據(jù)表的映射關(guān)系 5 ;?
6.??增、刪、改、查代碼示例?
- ?添加用戶示例
?語(yǔ)句描述:實(shí)例化一個(gè)Use對(duì)象(ID為自增,可不寫),是以對(duì)象的形式插入到數(shù)據(jù)庫(kù)中,Insert方法返回一個(gè)整型值,成功為1,否則為0。
注:該語(yǔ)句生成的sql語(yǔ)句為:
1 INSERT INTO [User] ( [Name], [Gender],[Age] ) 2 VALUES (@p0, 1 , 23) 3 -- p0:(DbType = String,Value = 新記錄)- 刪除用戶示例
語(yǔ)句描述:該方法是通過唯一標(biāo)識(shí)ID刪除數(shù)據(jù)庫(kù)中的一條記錄,Delete方法返回一個(gè)整型值,成功為1,否則為0。
?注:該語(yǔ)句生成的sql語(yǔ)句為:
1 DELETE FROM [User] 2 WhERE ( [ID] = 5 )- 修改用戶示例
語(yǔ)句描述:實(shí)例化一個(gè)Use對(duì)象(其中包含唯一的標(biāo)識(shí)),是以對(duì)象的形式通過唯一標(biāo)識(shí)找到該記錄并更新數(shù)據(jù)庫(kù)表中的記錄,Update方法返回一個(gè)整型值,成功為1,否則為0。
? 注:該語(yǔ)句生成的sql語(yǔ)句為: ?
1 UPDATE [User] 2 SET [Name] = @p0, [Gender] = 0, [Age] = 24 3 WHERE ( [ID] = 5 ) 4 -- p0:( DbType = String,Value = 修改新記錄 )- 查詢用戶示例
語(yǔ)句描述:第一條語(yǔ)句是查詢表中所有的記錄,存儲(chǔ)到User[]數(shù)組里面; 第二條語(yǔ)句查詢ID為5的記錄。
注:語(yǔ)句生成的sql語(yǔ)句分別為:?
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?
?????? 關(guān)系查詢Demo下載:http://files.cnblogs.com/xiaocaibaodao/Demo1.rar
轉(zhuǎn)載于:https://www.cnblogs.com/xiaocaibaodao/archive/2012/11/20/2778659.html
總結(jié)
以上是生活随笔為你收集整理的NLite.Data的应用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用万能头文件 #include<bit
- 下一篇: cva《财务建模》第五讲笔记