在向大家详细介绍Linq使用Select之前,首先让大家了解下Linq To Sql查询数据库,然后全面介绍Linq使用Select。
在宁化等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供做网站、网站设计 网站设计制作按需网站开发,公司网站建设,企业网站建设,成都品牌网站建设,营销型网站建设,成都外贸网站建设公司,宁化网站建设费用合理。
下面通过一些例子来说明怎样Linq使用Select,参考自:LINQ Samples
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. 组合查询,可以对多个数据源进行组合条件查询(相当于Linq使用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使用Select浅谈
转载来源:http://www.mswzjz.cn/qtweb/news29/222429.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能