LinqToSQL数据概括

学习Linq时,经常会遇到Linq To SQL数据问题,这里将介绍Linq To SQL数据问题的解决方法。

很久之前,在我刚学数据库编程的时候,就希望直接建一个数据库通用的操作类, 即写 Insert(类实例), 那么剩下的工作就交给底层代码来实现如何Insert。 现在接触了Linq, 感觉离这个梦想的实现已经不远了。

下面就分享一下我的源代码,很简单,估计刚学Linq的人也能看懂。

1. 建一个project 命名为DLinq ,添加一个Linq To SQL数据源,这里以经典的Northwind数据库为例,命名为NWDB.dbml 。

2. 建另一个Project 为DAL层 ,添加一个Table工厂, 这样我们就可以通过实体来获得Table

 
 
 
 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5.  
  6. namespace DAL  
  7. {  
  8. public staticclass TableFactory  
  9. {   
  10. public static System.Data.Linq.Table CreateTable() where T : class  
  11. {  
  12. return Database.NWDB.GetTable();  
  13. }  
  14. }  
 
 
 
 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5.  
  6. namespace DAL  
  7. {  
  8. publicstatic class Database  
  9. {  
  10. private static DLinq.NWDBDataContext _NWDB = null;  
  11.  
  12. public static DLinq.NWDBDataContext NWDB  
  13. {  
  14. get  
  15. {  
  16. if (_NWDB == null)  
  17. _NWDB = new DLinq.NWDBDataContext();  
  18. return _NWDB;  
  19. }  
  20. }  
  21.  
  22. }  

3. 借助Linq的特性,现在就可以写通用的数据库操作类了

 
 
 
 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5.  
  6. namespace DAL  
  7. {  
  8. public class Utility  
  9. {  
  10. public static void Insert(T TEntity) where T : class  
  11. {  
  12. var table = TableFactory.CreateTable();  
  13. table.InsertOnSubmit(TEntity);  
  14. }  
  15.  
  16. public static IEnumerable Where(Func, bool> predicate) where T : class  
  17. {  
  18. var table = TableFactory.CreateTable();  
  19. return table.Where(predicate).AsEnumerable();  
  20. }  
  21.  
  22. public static void SubmitChanges()  
  23. {  
  24. Database.NWDB.SubmitChanges();  
  25. }  
  26. }  

【编辑推荐】

  1. LINQ to SQL查询分析
  2. LINQ查询架构简单介绍
  3. LINQ to SQL映射关系概述
  4. LINQ To SQL对象模型浅析
  5. LINQ to SQL映射列描述

新闻名称:LinqToSQL数据概括
文章起源:http://www.shufengxianlan.com/qtweb/news1/467051.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联