日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

NLite.Data的应用

發(fā)布時(shí)間:2024/3/26 编程问答 52 豆豆
生活随笔 收集整理的這篇文章主要介紹了 NLite.Data的应用 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

  前段時(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.??增、刪、改、查代碼示例?

  • ?添加用戶示例
1 Model.User user = new Model.User 2 { 3 Name = "新記錄", 4 Age = 23, 5 Gender = true 6 }; 7 using (var ctx = cfg.CreateDbContext()) 8 ctx.Set<User>().Insert(user);

    ?語(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 = 新記錄)
  • 刪除用戶示例
1 using (var ctx = cfg.CreateDbContext()) 2 { 3 ctx.Set<User>().Delete(p=> p.ID == 5); 4 }

     語(yǔ)句描述:該方法是通過唯一標(biāo)識(shí)ID刪除數(shù)據(jù)庫(kù)中的一條記錄,Delete方法返回一個(gè)整型值,成功為1,否則為0。

?注:該語(yǔ)句生成的sql語(yǔ)句為:

1 DELETE FROM [User] 2 WhERE ( [ID] = 5 )
  • 修改用戶示例
1 Model.User user = new Model.User 2 { 3 ID = 5, 4 Name = "修改新記錄", 5 Age = 24, 6 Gender = false 7 }; 8 using (var ctx = cfg.CreateDbContext()) 9 ctx.Set<User>().Update(user);

     語(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 = 修改新記錄 )
  • 查詢用戶示例
1 using (var ctx = cfg.CreateDbContext()) 2 ctx.Set<User>().ToArray(); 3 //查詢所有的記錄 4 5 using (var ctx = cfg.CreateDbContext()) 6 ctx.Set<User>().Find(5); 7 //查詢ID為5的這條記錄

     語(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)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。