温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Linq to sql是什么意思

发布时间:2021-12-01 16:47:33 来源:亿速云 阅读:167 作者:小新 栏目:编程语言

这篇文章给大家分享的是有关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隐含类型局部变量

var age = 26;   var username = "zhuye";   var userlist = new [] {"a","b","c"};   foreach(var user in userlist)  Console.WriteLine(user);

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

Linq to sql匿名类型

var data = new {username = "zhuye",age = 26};  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自动属性

public class Person  {  public string username { get; protected set; }  public int age { get; set; }  public Person()  {  this.username = "zhuye";  }  }  Person p = new Person();  //p.username = "aa";  Console.WriteLine(p.username);

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

感谢各位的阅读!关于“Linq to sql是什么意思”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI