谁说LINQ复杂查询不支持返回实名类型~复杂结果集中再使用复杂结果集
下面代码主要是从一个复杂结果集中进行一个查询,在查询中使用的结果集还是一个复杂结果集。
什么是复杂结果集?
这是我给它的定义,它是由多张表进行关联查询后,生成的新的对象结果集或者原来结果集。如下图所示
GetUserInfoDetail()方法会产生一个复杂结果集,而GetUserBaseDetail()同样会产生一个复杂结果集,后者的结果集
而前者的结果集依赖。
代码如下:
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;
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了