提供.NET文章,资料,电子书,开发工具,专注于.NET技术推广  设为首页   加入收藏 
 登录   注册 
当前位置:首页 >> Linq

谁说LINQ复杂查询不支持返回实名类型~复杂结果集中再使用复杂结果集

出处: cnblogs | 2012-01-17 12:06:00 | 阅读:18 次
下面代码主要是从一个复杂结果集中进行一个查询,在查询中使用的结果集还是一个复杂结果集。 什么是复杂结果集? 这是我给它的定

下面代码主要是从一个复杂结果集中进行一个查询,在查询中使用的结果集还是一个复杂结果集。

什么是复杂结果集?

这是我给它的定义,它是由多张表进行关联查询后,生成的新的对象结果集或者原来结果集。如下图所示

GetUserInfoDetail()方法会产生一个复杂结果集,而GetUserBaseDetail()同样会产生一个复杂结果集,后者的结果集

而前者的结果集依赖。

image

代码如下:

namespace LINQ导航字段设计及返回实名类型
{
    class Program : LinqTestBase
    {
        static void Main(string[] args)
        {

            new Program().GetUserBaseDetail().ToList().ForEach(item =>
            {
                Console.WriteLine("用户:" + item.Name + ",真实姓名" + item.UserInfos_Extend.RealName);

                if (item.UserInfos_Extend.UserAddress_Extend != null && item.UserInfos_Extend.UserAddress_Extend.Count > 0)
                {
                    Console.WriteLine("用户常用地址为:");
                    item.UserInfos_Extend.UserAddress_Extend.ForEach(i =>
                    {
                        Console.WriteLine(i.Address);
                    });
                }
            });
            Console.ReadKey();
        }

        IQueryable<UserBases> GetUserBaseDetail()
        {
            var linq = from data1 in db.UserBases
                       join data2 in GetUserInfoDetail() on data1.UserID equals data2.UserID
                       select new UserBases_Ext
                      {
                          UserID = data1.UserID,
                          Name = data1.Name,
                          UserInfos_Extend = data2,
                      };
            return linq;

        }

        IQueryable<UserInfos> GetUserInfoDetail()
        {
            var linq = from data1 in db.UserInfos
                       join data3 in db.UserAddress on data1.UserID equals data3.UserID into list
                       select new UserInfos_Ext
                       {
                           UserID = data1.UserID,
                           RealName = data1.RealName,
                           UserAddress_Extend = list.ToList(),
                       };
            return linq;

        }
    }
}

分享到:
相关文章:
  文章评论 (共有条评论)
发表您的评论(文明评论 违者屏蔽 违规举报 请勿争吵)
  • 本站提供.NET相关的文章,资源,代码,软件等...
  • 测试期如有问题,请联系站长 QQ:61343211
  • 其中部分来源于网络,如果您对本站转载了您的作品表示不满意
  • 请联系我们,我们将在3个工作日之内删除!
  • 本站持续修改完善中,如遇不便还请谅解....
  • © 2010-2011 www.aspx2.com .NET程序员
  •  
  • 关注我们: