LINQ进行查询简单介绍

学习.NET Framework 3.5时,经常会遇到LINQ进行查询问题,这里将介绍LINQ进行查询问题的解决方法。

成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、成都网站制作、枣庄网络推广、小程序制作、枣庄网络营销、枣庄企业策划、枣庄品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供枣庄建站搭建服务,24小时服务热线:028-86922220,官方网址:www.cdcxhl.com

.NET Framework 3.5中引入了一个新特性LINQ(集成语言查询),据说.NET Framework 3.5中很多特性都是为LINQ而服务的,例如Lambda表达式的支持,匿名类型,等等……这篇文章会讲述一个把Linq to Object应用于测试的例子。

前一阵子需要测试一个搜索在线会员的功能,如果一个用户是在线的,那么他所能够被搜索到的信息都会作为一条记录,保存在一个表中,主要的字段有5 个,也就是根据这5个字段的信息可以查询出用户想要的在线会员。一个简单的方案就是写一个比较复杂的存储过程,然后根据5个输入来查询出不同的结果,不过 DBA说在SQL SERVER中进行逻辑运算的性能不是很好,所以开发人员写了12条存储过程,分别对应不同的组合,那么对于我做集成测试来说,我起码要有12个测试方法对应这12条存储过程。同时我还要设计一定数量的测试数据,供我查询测试,而比较要命的是,这些测试数据随着我对这个功能的理解的深入,在不断地增加,结果就是如果我写第一个测试的时候,我准备的数据是30条,OK,测试通过; 等我写到第五个测试的时候,测试数据可能有40条了,当我用这40条测试数据重新指向第一个测试的时候,FAILED!!!这让人非常郁闷。所以我想到了能不能用round trip的方法来进行测试。做一个比喻,假如说我想证明WIN7的计算器程序是正确的,那么可以把相同的计算在WIN XP的计算器中跑一遍,如果两者结果一样,那么我可以认为WIN7的计算器程序也是正确的(如果XP的计算器有错怎么办?先别较真,有风险,但很小)。

我的做法就是,准备一些数据,首先用SUT进行查询,然后用LINQ进行查询,如果两者查询结果一致,那么可以认为程序是正确的,否则就是两者之一存在问题。

首先准备一些测试数据,保存为XML文件,第一方便对测试数据进行CRUD,第二可以用XmlSerializer把这些数据转换为对象,方便用LINQ进行查询。

 
 
 
  1. < ?xml version="1.0" encoding="utf-8" ?> 
  2.  
  3.  
  4.  
  5. 1300010000 friendid> 
  6. 北京市 province> 
  7. 北京市 city> 
  8. 18 age> 
  9. 2 gender> 
  10. true hasphoto> 
  11. onlinefrienddata> 
  12.  
  13. 1300010002 friendid> 
  14. 北京市 province> 
  15. 北京市 city> 
  16. 27 age> 
  17. 2 gender> 
  18. false hasphoto> 
  19. onlinefrienddata> 
  20.  
  21. 1300010004 friendid> 
  22. 广东省 province> 
  23. 广州市 city> 
  24. 45 age> 
  25. 1 gender> 
  26. true hasphoto> 
  27. onlinefrienddata> 
  28. friends> 
  29. onlinefriends> 

【编辑推荐】

  1. LINQ to SQL数据表介绍
  2. LINQ查询的目的与实现手段
  3. LINQ from子句进行复合查询实现方法
  4. LINQ查询表达式功能详解
  5. LINQ基础概念总结

本文标题:LINQ进行查询简单介绍
分享URL:http://www.shufengxianlan.com/qtweb/news9/301959.html

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

广告

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