DefaultIfEmpty and Left Outer Join

6 篇文章 0 订阅

http://www.xmaspx.com/u/guitarpark/Blog.aspx/t-19

  DefaultIfEmpty函数:若指定数据源为空的时候,返回一个默认值,此函数延时加载。
例:
int[] ints = { 1, 2, 3, 4, 5, 6 };
                var result = ints.DefaultIfEmpty();
     foreach (int x in result)
                Response.Write(x);
由于ints数组不为空,所以最后输出结果为123456。
 
int[] ints = { 1, 2, 3, 4, 5, 6 };
                var result = ints.DefaultIfEmpty(-1);
     foreach (int x in result)
                Response.Write(x);
同上,由于ints数组不为空,所以最后输出结果为123456。
 
int[] ints = { };
                var result = ints.DefaultIfEmpty(-1);
     foreach (int x in result)
                Response.Write(x);
由于ints数组为空,所以最后输出结果为ints1.DefaultIfEmpty(-1)中指定的-1。


http://www.cnblogs.com/cs_net/articles/2059846.html

 左外连接与SqL中left join一样。如下例找出根据publisher中找出SampleData.Publishers中所有资料和book中存在于publisher的资料。

     左外连接查询语句如下:

复制代码
             // left join, 为空时用default
            var leftJoinQuerybyDefault  =  from publisher  in  SampleData.Publishers
                                         join book 
in  SampleData.Books
                                           on publisher equals book.Publisher into publisherBooks
                                         from book 
in  publisherBooks.DefaultIfEmpty()
                                         select 
new
                                         {
                                             PublisherName 
=  publisher.Name,
                                             BookName 
=  (book  ==   default (Book))  ?   " no book "  : book.Title
                                         };
复制代码

     注:上例中使用了DefaultIfEmpty操作符,它能够为实序列提供一个默认的元素。DefaultIfEmpty使用了泛型中的default关键字。default关键字对于引用类型将返回null,而对于值类型则返回0。对于结构体类型,则会根据其成员类型将它们相应地初始化为null(引用类型)或0(值类型)。

    我们可以不使用default关键字,但在要DefaultIfEmpty中给定当空时的默认对象值。语句如下:

复制代码
             // left join, 为空时使用默认对象
            var leftJoinQuery  =  from publisher  in  SampleData.Publishers
                                        join book 
in  SampleData.Books
                                          on publisher equals book.Publisher into publisherBooks
                                        from book 
in  publisherBooks.DefaultIfEmpty(
                                        
new  Book { Title  =   ""  }                          // 设置为空时的默认值
                                        )
                                        select 
new
                                        {
                                            PublisherName 
=  publisher.Name,
                                            BookName 
=  book.Title
                                        };


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值