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();
}
}
{
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();
}
}
相关文章推荐
- LinQ to Object --- 有关于Dictionary、SQL(LEFT OUTER JOIN \ Group OrderBy Sum) 操作
- SQO (标准查询运算符)方法 & Linq To Object
- .NET编程(03)Lambda&Linq(to object)
- [导入]LINQ体验(13)——LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL
- 在net中json序列化与反序列化 面向对象六大原则 (第一篇) 一步一步带你了解linq to Object 10分钟浅谈泛型协变与逆变
- LINQ体验(6)——LINQ to SQL语句之Join和Order By
- LINQ TO Object
- C#——LINQ to object 基本用法(
- LINQ to SQL语句之Join和Order By
- Linq to SQL 语法查询(子查询 & in操作 & join )
- (第一篇) 一步一步带你了解linq to Object
- 【vs.net 2008系列-LINQ】 == to object 文章索引 ==
- EF Linq To Entities ObjectManager 已存在相同键无法再Attach的解决方案
- Linq学习笔记(三)Linq To Object查询操作符
- Linq to object 技巧、用法集锦
- LinqToSql 动态查询条件,join, isnull 综合示例
- LINQ系列:Linq to Object聚合操作符
- LINQ&EF任我行(二)--LinQ to Object
- Linq to EF 与Linq to Object 使用心得
- Linq to Object