Linq To SQL数据概括

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

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

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

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

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

Northwind数据库

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<T> CreateTable<T>() where T : class  
  11. {  
  12. return Database.NWDB.GetTable<T>();  
  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>(T TEntity) where T : class  
  11. {  
  12. var table = TableFactory.CreateTable<T>();  
  13. table.InsertOnSubmit(TEntity);  
  14. }  
  15.  
  16. public static IEnumerable<T> Where<T>(Func<T, bool> predicate) where T : class  
  17. {  
  18. var table = TableFactory.CreateTable<T>();  
  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映射列描述
责任编辑:佚名 来源: 博客园
相关推荐

2009-09-18 14:07:51

LINQ to SQL

2009-09-16 17:33:16

LINQ TO SQL

2009-09-18 15:15:12

LINQ to SQL

2009-09-14 15:37:06

LINQ映射数据库

2009-09-16 16:52:50

LINQ to XML

2009-09-16 10:27:35

LINQ Custom

2009-09-16 10:08:06

LINQ查询

2009-09-15 13:59:18

LINQ to Dat

2009-09-15 16:09:12

LINQ进行查询

2009-09-14 16:51:33

LINQ XML树加载

2009-09-09 15:10:35

LINQ查询句法

2009-09-16 16:55:07

LINQ to XML

2009-09-15 09:50:07

Linq操作数据库

2009-09-15 15:18:00

Linq Lambda

2009-09-15 17:30:00

Linq Lambda

2009-09-18 15:19:19

LINQ to SQL

2009-09-07 16:13:14

LINQ to SQL

2009-09-18 14:25:36

LINQ to SQL

2009-09-15 10:02:44

Linq to SQL

2009-09-08 14:45:24

Linq to SQL支持SQL Serve
点赞
收藏

51CTO技术栈公众号