Linq to sql基础总结

开发 后端
这里介绍Linq to sql基础,包括介绍定义一个临时的匿名类型在LINQ查询句法中非常常见,我们可以很方便的实现对象的转换和投影。

Linq to sql有很多值得学习的地方,这里我们主要介绍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. var username = "zhuye";  
  3. var userlist = new [] {"a","b","c"};  
  4. foreach(var user in userlist)  
  5. 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的基础。定义扩展方法需要注意,只能在静态类中定义并且是静态方法,如果扩展方法名和原有方法名发生冲突,那么扩展方法将失效。

【编辑推荐】

  1. Linq匿名类型简单概述
  2. Linq随机读取数据浅析
  3. Linq Lambda表达式全面分析
  4. Linq扩展方法简单分析
  5. 初探Linq局部变量类型
责任编辑:佚名 来源: 华夏网管站
相关推荐

2009-08-27 10:14:04

LINQ基础概念

2009-09-17 17:14:54

linq to sql

2009-09-16 17:44:54

LINQ to SQL

2009-09-17 13:54:26

LINQ to XML

2009-09-08 14:45:24

Linq to SQL支持SQL Serve

2009-09-09 14:40:43

Linq to sql

2009-09-10 11:29:00

LINQ to SQL

2009-09-08 13:16:01

Linq to SQL

2009-09-15 17:07:24

Linq To SQL

2009-09-16 17:33:16

LINQ TO SQL

2009-09-11 12:08:09

Linq to SQL

2009-09-18 14:51:19

LINQ TO SQL

2009-09-11 12:13:40

LINQ to SQL

2009-09-18 14:33:37

LINQ to SQLSQL命令

2009-09-16 10:08:06

LINQ查询

2009-09-18 16:20:36

LINQ基础

2009-09-18 13:23:27

Northwind对象LINQ to SQL

2009-09-10 10:37:15

LINQ to SQL

2009-09-08 13:07:15

介绍Linq to S

2009-09-10 18:02:23

LINQ to SQL
点赞
收藏

51CTO技术栈公众号