LINQ的Select
2014-01-03 15:18
295 查看
下面通过一些例子来说明怎样使用select,参考自:LINQ Samples
1. 可以对查询出来的结果做一些转换,下面的例子在数组中查找以"B"开头的名字,然后全部转成小写输出:
2. 返回匿名类型,比如Linq To Sql查询数据库的时候只返回需要的信息,下面的例子是在Northwind数据库中查询Customer表,返回所有名字以"B"开头的客户的ID和名称:
3. 对于数组,select可以对数组元素以及索引进行操作:
4. 组合查询,可以对多个数据源进行组合条件查询(相当于使用SelectMany函数),下面的例子其实就相对于一个双重循环遍历:
而用Linq To Sql的话,相当于进行一次子查询:
1. 可以对查询出来的结果做一些转换,下面的例子在数组中查找以"B"开头的名字,然后全部转成小写输出:
string[] names = { "Jack", "Bob", "Bill", "Catty", "Willam" }; var rs = from n in names where n.StartsWith("B") select n.ToLower(); foreach (var r in rs) Console.WriteLine(r);
2. 返回匿名类型,比如Linq To Sql查询数据库的时候只返回需要的信息,下面的例子是在Northwind数据库中查询Customer表,返回所有名字以"B"开头的客户的ID和名称:
NorthwindDataContext dc = new NorthwindDataContext(); var cs = from c in dc.Customers where c.ContactName.StartsWith("B") select new { CustomerID = c.CustomerID, CustomerName = c.ContactTitle + " " + c.ContactName }; foreach (var c in cs) Console.WriteLine(c);
3. 对于数组,select可以对数组元素以及索引进行操作:
string[] names = { "Jack", "Bob", "Bill", "Catty", "Willam" }; var rs = names.Select((name, index) => new { Name = name, Index = index }); foreach (var r in rs) Console.WriteLine(r);
4. 组合查询,可以对多个数据源进行组合条件查询(相当于使用SelectMany函数),下面的例子其实就相对于一个双重循环遍历:
int[] numbersA = { 0, 2, 4, 5, 6, 8, 9 }; int[] numbersB = { 1, 3, 5, 7, 8 }; var pairs = from a in numbersA, b in numbersB where a < b select new {a, b}; Console.WriteLine("Pairs where a < b:"); foreach (var pair in pairs) Console.WriteLine("{0} is less than {1}", pair.a, pair.b);
而用Linq To Sql的话,相当于进行一次子查询:
NorthwindDataContext dc = new NorthwindDataContext(); var rs = from c in dc.Customers from o in c.Orders where o.ShipCity.StartsWith("B") select new { CustomerName = c.ContactName, OrderID = o.OrderID }; foreach (var r in rs) Console.WriteLine(r);
相关文章推荐
- LINQ to SQL语句(2)之Select/Distinct
- LINQ to SQL 语句(2)之 Select/Distinct
- LINQ 中的 select
- 步步为营VS 2008 + .NET 3.5(5) - LINQ查询操作符之Select、Where、OrderBy、OrderByDescending、GroupBy、Join、GroupJoin及其对应的查询语法
- LINQ to SQL语句之Select/Distinct和Count/Sum/Min/Max/Avg (转)
- linq语法之select distinct Count Sum Min Max Avg
- nhibernate3 linq的的select 操作
- LINQ查询表达式---------select子句
- Linq:基本语法form ,select, where(2)
- LINQ 中的 select
- linq 的查询的学习 (google 中输入 101 linq) -- select的应用
- LINQ傻瓜教学之三:更改列名如何写select isnull(column1,0) as StoreName from table1
- 步步为营VS 2008 + .NET 3.5(5) - LINQ查询操作符之Select、Where、OrderBy、OrderByDescending、GroupBy、Join、GroupJoin及其对应的查询语法
- LINQ体验(5)——LINQ to SQL语句之Select/Distinct和Count/Sum/Min/Max/Avg
- Linq第三天-Select 操作
- 为何Linq以from开头而不以select 开头
- LINQ体验(5)——LINQ to SQL语句之Select/Distinct和Count/Sum/Min/Max/Avg
- LINQ体验(5)--LINQ to SQL语句之Select/Distinct和Count/Sum/Min/Max/Avg
- LINQ to SQL语句之Where/Select/Distinct
- Linq中的Select与Select many