Linq to sql全面剖析

开发 后端
这里介绍Linq to sql(或者叫DLINQ)是LINQ(.NET语言集成查询)的一部分,全称基于关系数据的 .NET 语言集成查询,用于以对象形式管理关系数据,并提供了丰富的查询功能。

Linq有很多值得学习的地方,这里我们主要介绍Linq to sql,包括介绍Linq to sql隐含类型局部变量等方面。

什么是Linq to sql

Linq to sql(或者叫DLINQ)是LINQ(.NET语言集成查询)的一部分,全称基于关系数据的 .NET 语言集成查询,用于以对象形式管理关系数据,并提供了丰富的查询功能,它和Linq to xml、Linq to objects、Linq to dataset、Linq to entities等组成了强大的LINQ。

要学好LINQ查询语法,就不得不先理解C# 3.0的一些新特性,下面一一简单介绍。

Linq to sql隐含类型局部变量

  1. var age = 26;  
  2.  
  3. var username = "zhuye";  
  4.  
  5. var userlist = new [] {"a","b","c"};  
  6.  
  7. foreach(var user in userlist)  
  8. Console.WriteLine(user); 

纯粹给懒人用的var关键字,告诉编译器(对于CLR来说,它是不会知道你是否使用了var,苦力是编译器出的),你自己推断它的类型吧,我不管了。但是既然让编译器推断类型就必须声明的时候赋值,而且不能是null值。注意,这只能用于局部变量,用于字段是不可以的。

Linq to sql匿名类型

  1. var data = new {username = "zhuye",age = 26};  
  2. Console.WriteLine("username:{0} age:{1}", data.username, data.age); 

匿名类型允许开发人员定义行内类型,无须显式定义类型。常和var配合使用,var用于声明匿名类型。定义一个临时的匿名类型在LINQ查询句法中非常常见,我们可以很方便的实现对象的转换和投影。

Linq to sql扩展方法

  1. public static class helper  
  2. {  
  3. public static string MD5Hash(this string s)  
  4. {  
  5. return System.Web.Security.FormsAuthentication.
    HashPasswordForStoringInConfigFile(s,"MD5");  
  6. }  
  7. public static bool In(this object o, IEnumerable b)  
  8. {  
  9. foreach(object obj in b)  
  10. {  
  11. if(obj==o)  
  12. return true;  
  13. }  
  14. return false;  
  15. }  
  16. }  
  17. // 调用扩展方法  
  18. Console.WriteLine("123456".MD5Hash());  
  19. Console.WriteLine("1".In(new[]{"1","2","3"})); 

很多时候我们需要对CLR类型进行一些操作,苦于无法扩展CLR类型的方法,只能创建一些helper方法,或者生成子类。扩展方法使得这些需求得意实现,同时也是实现LINQ的基础。定义扩展方法需要注意,只能在静态类中定义并且是静态方法,如果扩展方法名和原有方法名发生冲突,那么扩展方法将失效。

Linq to sql自动属性

  1. public class Person  
  2. {  
  3. public string username { get; protected set; }  
  4. public int age { get; set; }  
  5. public Person()  
  6. {  
  7. this.username = "zhuye";  
  8. }  
  9. }  
  10. Person p = new Person();  
  11. //p.username = "aa";  
  12. Console.WriteLine(p.username); 

意义不是很大,纯粹解决机械劳动。编译器自动为你生成get、set操作以及字段,并且你不能使用字段也不能自定义get、set操作,不过你可以分别定义get和set的访问级别。

【编辑推荐】

  1. Linq结果集形状概述
  2. Linq存储过程返回详解
  3. Linq调用LoadProducts方法
  4. Linq使用数据表简单描述
  5. Linq对象引用简单介绍
责任编辑:佚名 来源: IT168
相关推荐

2009-09-17 13:15:20

LINQ查询

2009-09-18 17:17:58

LINQ模型

2009-09-11 12:13:40

LINQ to SQL

2009-09-08 16:20:12

LINQ to SQL

2009-09-16 09:56:42

LINQ to SQL

2009-09-07 16:25:14

Linq To SQL

2009-09-17 15:22:38

LINQ to SQL

2009-09-15 10:59:10

LinQ to SQL

2009-09-14 15:12:40

LINQ to XML

2009-09-09 16:21:31

Linq使用sqlme

2009-09-14 10:13:02

LINQ查询操作

2009-09-16 16:59:05

LINQ to XML

2009-09-10 14:37:57

LINQ匿名类型

2009-09-16 17:21:53

LINQ遍历

2009-09-16 10:38:43

LINQ查询

2009-09-18 16:20:36

LINQ基础

2009-09-17 09:20:34

Linq和dLinq区

2009-09-08 15:39:13

Linq使用Inser

2009-09-15 14:52:15

linq级联删除

2009-09-14 10:35:15

Linq内部执行原理
点赞
收藏

51CTO技术栈公众号