LINQ to SQL语句之Where/Select/Distinct

来源:互联网 发布:淘宝搜索排名 编辑:程序博客网 时间:2024/06/11 02:58

注: 本文是本人收集,资源来至网络,作为笔记留存。

一、Where操作                                                           

适用场景:实现过滤,查询等功能。

说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句。

Where操作包括3种形式,分别为简单形式、关系条件形式、First()形式。下面分别用实例举例下:

1.简单形式:

例如:使用where筛选在伦敦的客户

var q =    from c in db.Customers    where c.City == "London"    select c;

再如:筛选1994 年或之后雇用的雇员:

var q =    from e in db.Employees    where e.HireDate >= new DateTime(1994, 1, 1)    select e;

2.关系条件形式:

筛选库存量在订货点水平之下但未断货的产品:

var q =    from p in db.Products    where p.UnitsInStock <= p.ReorderLevel && !p.Discontinued    select p;

筛选出UnitPrice 大于10 或已停产的产品:

var q =    from p in db.Products    where p.UnitPrice > 10m || p.Discontinued    select p;

下面这个例子是调用两次where以筛选出UnitPrice大于10且已停产的产品。

var q =    db.Products.Where(p=>p.UnitPrice > 10m).Where(p=>p.Discontinued);

3.First()形式:

返回集合中的一个元素,其实质就是在SQL语句中加TOP (1)。

简单用法:选择表中的第一个发货方。

Shipper shipper = db.Shippers.First();

元素:选择CustomerID 为“BONAP”的单个客户

Customer cust = db.Customers.First(c => c.CustomerID == "BONAP");

条件:选择运费大于 10.00 的订单:

Order ord = db.Orders.First(o => o.Freight > 10.00M);


二、Select/Distinct操作符                                               

适用场景:o(∩_∩)o… 查询呗。

说明:和SQL命令中的select作用相似但位置不同,查询表达式中的select及所接子句是放在表达式最后并把子句中的变量也就是结果返回回来;延迟。

Select/Distinct操作包括9种形式,分别为简单用法、匿名类型形式、条件形式、指定类型形式、筛选形式、整形类型形式、嵌套类型形式、本地方法调用形式、Distinct形式。

1.简单用法:

这个示例返回仅含客户联系人姓名的序列。

var q =    from c in db.Customers    select c.ContactName;

注意:这个语句只是一个声明或者一个描述,并没有真正把数据取出来,只有当你需要该数据的时候,它才会执行这个语句,这就是延迟加载(deferred loading)。如果,在声明的时候就返回的结果集是对象的集合。你可以使用ToList() 或ToArray()方法把查询结果先进行保存,然后再对这个集合进行查询。当然延迟加载(deferred loading)可以像拼接SQL语句那样拼接查询语法,再执行它。

2.匿名类型形式:

说明:匿名类型是C#3.0中新特性。其实质是编译器根据我们自定义自动产生一个匿名的类来帮助我们实现临时变量的储存。匿名类型还依赖于另外一个特性:支持根据property来创建对象。比如,var d = new { Name = "s" };编译器自动产生一个有property叫做Name的匿名类,然后按这个类型分配内存,并初始化对象。但是var d = new {"s"};是编译不通过的。因为,编译器不知道匿名类中的property的名字。例如string c = "d";var d = new { c}; 则是可以通过编译的。编译器会创建一个叫做匿名类带有叫c的property。
例如下例:new{c,ContactName,c.Phone};ContactName和Phone都是在映射文件中定义与表中字段相对应的property。编译器读取数据并创建对象时,会创建一个匿名类,这个类有两个属性,为ContactName和Phone,然后根据数据初始化对象。另外编译器还可以重命名property的名字。

var q =    from c in db.Customers    select new {c.ContactName, c.Phone};

上面语句描述:使用 SELECT 和匿名类型返回仅含客户联系人姓名和电话号码的序列

var q =    from e in db.Employees    select new    {        Name = e.FirstName + " " + e.LastName,        Phone = e.HomePhone    };

上面语句描述:使用SELECT和匿名类型返回仅含雇员姓名和电话号码的序列,并将FirstName和LastName字段合并为一个字段“Name”,此外在所得的序列中将HomePhone字段重命名为Phone。

var q =    from p in db.Products    select new    {        p.ProductID,        HalfPrice = p.UnitPrice / 2    };
上面语句描述:使用SELECT和匿名类型返回所有产品的ID以及HalfPrice(设置为产品单价除以2所得的值)的序列。

3.条件形式:

说明:生成SQL语句为:case when condition then else。

var q =    from p in db.Products    select new    {        p.ProductName,        Availability =        p.UnitsInStock - p.UnitsOnOrder < 0 ?         "Out Of Stock" : "In Stock"    };

上面语句描述:使用SELECT和条件语句返回产品名称和产品供货状态的序列。

4.指定类型形式:

说明:该形式返回你自定义类型的对象集。

var q =    from e in db.Employees    select new Name    {        FirstName = e.FirstName,        LastName = e.LastName    };

上面语句描述:使用SELECT和已知类型返回雇员姓名的序列。

5.筛选形式:

说明:结合where使用,起到过滤作用。

var q =    from c in db.Customers    where c.City == "London"    select c.ContactName;

上面语句描述:使用SELECT和WHERE返回仅含伦敦客户联系人姓名的序列。

6.shaped形式(整形类型):

说明:其select操作使用了匿名对象,而这个匿名对象中,其属性也是个匿名对象。

var q =    from c in db.Customers    select new {        c.CustomerID,        CompanyInfo = new {c.CompanyName, c.City, c.Country},        ContactInfo = new {c.ContactName, c.ContactTitle}    };

语句描述:使用SELECT 和匿名类型返回有关客户的数据的整形子集。查询顾客的ID和公司信息(公司名称,城市,国家)以及联系信息(联系人和职位)。

7.嵌套类型形式:

说明:返回的对象集中的每个对象DiscountedProducts属性中,又包含一个集合。也就是每个对象也是一个集合类。

var q =    from o in db.Orders    select new {        o.OrderID,        DiscountedProducts =            from od in o.OrderDetails            where od.Discount > 0.0            select od,        FreeShippingDiscount = o.Freight    };

语句描述:使用嵌套查询返回所有订单及其OrderID 的序列、打折订单中项目的子序列以及免送货所省下的金额。

8.本地方法调用形式(LocalMethodCall):

这个例子在查询中调用本地方法PhoneNumberConverter将电话号码转换为国际格式。

var q = from c in db.Customers         where c.Country == "UK" || c.Country == "USA"         select new         {             c.CustomerID,             c.CompanyName,             Phone = c.Phone,             InternationalPhone =              PhoneNumberConverter(c.Country, c.Phone)         };

PhoneNumberConverter方法如下:

public string PhoneNumberConverter(string Country, string Phone){    Phone = Phone.Replace(" ", "").Replace(")", ")-");    switch (Country)    {        case "USA":            return "1-" + Phone;        case "UK":            return "44-" + Phone;        default:            return Phone;    }}

下面也是使用了这个方法将电话号码转换为国际格式并创建XDocument

XDocument doc = new XDocument(    new XElement("Customers", from c in db.Customers              where c.Country == "UK" || c.Country == "USA"              select (new XElement("Customer",                      new XAttribute("CustomerID", c.CustomerID),                      new XAttribute("CompanyName", c.CompanyName),                      new XAttribute("InterationalPhone",                        PhoneNumberConverter(c.Country, c.Phone))                     ))));

9.Distinct形式:

说明:筛选字段中不相同的值。用于查询不重复的结果集。生成SQL语句为:SELECT DISTINCT [City] FROM [Customers]

var q = (    from c in db.Customers    select c.City )    .Distinct();
语句描述:查询顾客覆盖的国家。

第一篇完,2013-12-19 14:36












0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 被加密的视频无法观看怎么办 苹果5忘记id密码怎么办 七个月宝宝脾胃不好怎么办 八个月宝宝脾虚怎么办 七个月宝宝脾胃虚怎么办 海岛奇兵点错了怎么办 螳螂的脚断了怎么办 海岛奇兵打不过玩家怎么办 海岛奇兵资源满了怎么办 海岛奇兵杯越来越多打不玩家怎么办 海岛奇兵控杯技巧 杯数太高怎么办 海岛奇兵发现求救信号怎么办 海岛奇兵被打了怎么办 小鱼翅卡喉咙了怎么办 鱼翅卡在喉咙里怎么办 斗鱼身份证被使用怎么办 做的鱼丸太腥了怎么办 做鱼丸太稀了怎么办 斗鱼手机号换了怎么办 斗鱼直播掉帧怎么办 手机一直卡顿点不动怎么办呢 斗鱼直播分值底怎么办 斗鱼6000鱼丸怎么办卡 斗鱼直播没人看怎么办 淘宝直播间没人气怎么办 挂水了还是有热度怎么办 陌陌工会不结算工资怎么办 滴滴给了差评怎么办 饿了么星级低怎么办 滴滴乘客给低星怎么办 蘑菇街自动收货前还没到怎么办 小主播人气太少别人看不到怎么办 税收分类编码不可用怎么办 斗鱼鱼翅充错了怎么办 苹果指纹摔坏了怎么办 小米5指纹坏了怎么办 苹果5s指纹失灵怎么办 学生赌博输了3万怎么办 电脑录屏没有声音怎么办 别人说你没有他美怎么办 没有你我怎么办歌词是什么意思