2012-04-12 73 views
1

我得到了树型对象。linq查询语法,如何产生两个列表组合的一个条件

一个对象EFacebook,很简单,有一个属性叫做id

class EFacebook 
{ 
    public string id { get; set; } 
} 

A EUser,更复杂。 EUser获取内部列表EProvider,并且每个EProvider获得一个类型。像:

class EUser 
{ 
    public string name { get; set; } 
    public List<EProvider> EProviders { get; set; } 
} 

class EProvider 
{ 
    public enum EnumType 
    { 
     facebook = 1, 
     twitter = 2 
    } 
    public string id { get; set; } 
    public EnumType type { get; set; } 
} 

而且两个列表:(供应商,内部的用户,列表是可选的,可为空):

// list of facebooks 
List<EFacebook> facebooks = new List<EFacebook>(); 

facebooks.Add(new EFacebook { id = "1" }); 
facebooks.Add(new EFacebook { id = "2" }); 
facebooks.Add(new EFacebook { id = "3" }); 

// list of users 
List<EUser> users = new List<EUser>(); 
List<EProvider> ps1 = new List<EProvider>(); 

ps1.Add(new EProvider { id = "1", type = EProvider.EnumType.facebook }); 
ps1.Add(new EProvider { id = "2", type = EProvider.EnumType.twitter }); 

List<EProvider> ps2 = new List<EProvider>(); 
ps2.Add(new EProvider { id = "3", type = EProvider.EnumType.facebook }); 
ps2.Add(new EProvider { id = "4", type = EProvider.EnumType.twitter }); 

EUser u1 = new EUser { name = "somea", EProviders = ps1 }; 
EUser u2 = new EUser { name = "someb", EProviders = ps2 }; 
EUser u3 = new EUser { name = "somec" }; 

users.Add(u1); 
users.Add(u2); 
users.Add(u3); 

现在,我需要获得基于关系的facebooks两个孩子名单在facebook.iduser.eprovider(of enum facebook).id之间。这意味着,的EFacebook只包含对象facebookid 2的列表,因为我没有与facebook类型和id 2的提供者的用户,并且包含所述对象facebookEFacebookid 1和3的列表,因为我确实有facebook类型的providerid 1和id 3.

我尝试了很多用户,但它不工作:

/*var xaa = users.Select(z => z.EProviders.Where(x => x.ProviderType == 
    EProvider.EnumProviderType.Facebook).Select(x => x.Ip).Zip(z);*/ 

/*var a = users.Select(x => x.EProviders.Where(y => y.ProviderType == 
    EProvider.EnumProviderType.Facebook));*/ 


/* 
var outra = facebooks.Where(x=>     
var a = from i in users 
    where i.EProviders != null && i.EProviders.Any(j => j.ProviderType == 
    EProvider.EnumProviderType.Facebook) 
from j in i.EProviders 
join k in facebooks on j.Ip equals k.id 
select k; 

var b = facebooks.Except(a); 
*/ 

任何帮助将不胜感激。

+0

您还没有涉及到EProvider对象EFacebook对象及其ID值和它们的ID值,但随后从“现在怎么解释,我需要..“段落似乎我们要推断他们是相关的?请进一步解释或编辑问题的清晰度。 – 2012-04-12 16:09:17

+0

我觉得现在好多了。英语这不是我的第一语言,我很抱歉。 – lolol 2012-04-12 16:13:41

回答

2

如何:

// Create an enumerable of all IDs of Facebook providers from the users list 
var facebookIds = users 
    // Exclude all users with a null EProviders list 
    .Where(u => u.EProviders != null) 
    // For each user, select all EProviders with type == facebook 
    // and use SelectMany to flatten them into a single enumerable 
    .SelectMany(u => u.EProviders.Where(p => p.type == EProvider.EnumType.facebook)); 

// Use Join to find all facebooks whose IDs also exist in the facebookIds set constructed above 
var facebooksWithUsers = facebooks.Join(facebookIds, f => f.id, p => p.id, (f, p) => f); 

// Use Except to find the opposite subset 
var facebooksWithoutUsers = facebooks.Except(facebooksWithUsers); 

// Write the contents of the two sets to the console 
Console.WriteLine("facebooksWithUsers:"); 
foreach (var fb in facebooksWithUsers) 
{ 
    Console.WriteLine(fb.id); 
} 

Console.WriteLine(); 
Console.WriteLine("facebooksWithoutUsers:"); 
foreach (var fb in facebooksWithoutUsers) 
{ 
    Console.WriteLine(fb.id); 
} 

此输出:

 
facebooksWithUsers: 
1 
3 

facebooksWithoutUsers: 
2 
+1

就我的问题而言,这正是您所要求的 - facebooksWithUsers包含ID为1和3的脸书,facebooksWithoutUsers包含脸书ID为2 – Iridium 2012-04-12 16:29:13

+0

我认为这是行得通的。我不好,让我再试一次。 (它是) – lolol 2012-04-12 16:32:22