您的位置:首页 > 移动开发 > Objective-C

LINQ to Object(集运算符与JOIN)

2012-04-18 15:18 387 查看
class Order

{

public string ID { get; set; }

public decimal Amount { get; set; }

}

class Customer

{

public string ID { get; set; }

public string City { get; set; }

public string Country { get; set; }

public string Region { get; set; }

public decimal Sales { get; set; }

public override string ToString()

{

return "ID:" + ID + "City:" + City + "Country:" + Country +

"Region:" + Region + "Sales:" + Sales;

}

}

class Program

{

static void Main(string[] args)

{

List<Customer> customers = new List<Customer>{

new Customer{ID = "A",City = "New York", Country = "USA",

Region = "North American", Sales = 999},

new Customer{ID = "B",City = "Mumbai", Country = "India",

Region = "Asia", Sales = 888},

new Customer{ID = "C",City = "Karachi", Country = "Pakistan",

Region = "Asia", Sales = 777},

new Customer{ID = "D",City = "Delhi", Country = "India",

Region = "Asia", Sales = 666},

new Customer{ID = "E",City = "So Paul", Country = "Brazil",

Region = "South America", Sales = 555},

new Customer{ID = "F",City = "Moscow", Country = "Russia",

Region = "Europe", Sales = 444},

new Customer{ID = "G",City = "Seoul", Country = "Korea",

Region = "Asia", Sales = 333},

new Customer{ID = "H",City = "Istanbul", Country = "Turkey",

Region = "Asia", Sales = 222},

new Customer{ID = "I",City = "Shanghai", Country = "China",

Region = "Asia", Sales = 1111},

new Customer{ID = "J",City = "Lagos", Country = "Nigeria",

Region = "Africa", Sales = 1000}};

List<Order> orders = new List<Order>{

new Order{ID="E", Amount = 100},

new Order{ID="F", Amount = 200},

new Order{ID="G", Amount = 300},

new Order{ID="H", Amount = 400},

new Order{ID="I", Amount = 500},

new Order{ID="J", Amount = 600},

new Order{ID="K", Amount = 700},

new Order{ID="L", Amount = 800},

new Order{ID="M", Amount = 900},

new Order{ID="N", Amount = 1000},

new Order{ID="O", Amount = 1100}};

var customerIDs =

from c in customers

select c.ID;

var orderIDs =

from o in orders

select o.ID;

//-----------------------------------------Intersect、Excpt、Union用法 begin----------------------------------------------------

/* var customersWithOrders = customerIDs.Intersect(orderIDs);//两个集合的交集

foreach (var item in customersWithOrders)

{

Console.WriteLine(item);

}

var customersWithOrders = customerIDs.Except(orderIDs);//第一个结果集中有,而第二个结果集中没有的项

foreach (var item in customersWithOrders)

{

Console.WriteLine(item);

}

var customersWithOrders = customerIDs.Union(orderIDs);//两个集合的并集 并删除重复项

foreach (var item in customersWithOrders)

{

Console.Write("{0} ",item);

}*/

//-----------------------------------------Intersect、Excpt、Union用法 end----------------------------------------------------

//-------------------------------------------------join用法 begin----------------------------------------------------

var queryResults =

from c in customers

join o in orders on c.ID equals o.ID

select new { c.ID, c.City, SalesBefore = c.Sales, NewOrder = o.Amount, SalesAfter = c.Sales + o.Amount };

foreach (var item in queryResults)

{

Console.WriteLine(item);

}

//-------------------------------------------------join用法 end----------------------------------------------------

Console.WriteLine();

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: