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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

NLite.Data的应用

發布時間:2024/3/26 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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.??增、刪、改、查代碼示例?

  • ?添加用戶示例
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);

    ?語句描述:實例化一個Use對象(ID為自增,可不寫),是以對象的形式插入到數據庫中,Insert方法返回一個整型值,成功為1,否則為0。

     注:該語句生成的sql語句為:

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 }

     語句描述:該方法是通過唯一標識ID刪除數據庫中的一條記錄,Delete方法返回一個整型值,成功為1,否則為0。

?注:該語句生成的sql語句為:

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);

     語句描述:實例化一個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 = 修改新記錄 )
  • 查詢用戶示例
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的這條記錄

     語句描述:第一條語句是查詢表中所有的記錄,存儲到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的应用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。