SQL,Linq,Lambda之间的转换练习
1、查询Student表中的所有记录的Sname、Ssex和Class列。
SQL:select sname,ssex,class from Students
linq:from s in Students select new{s.sname,s.ssex,s.class}
lambda:Students.select(s=>new{sname=s.sname,ssex=s.ssex,class=s.class})
2、查询教师所有的单位即不重复的Depart列。
SQL:select distinct depart from Teachers
linq:from t in Teachers.distinct() select t.depart
lambda:Teachers.distinct().select(t=>t.depart)
3、查询Student表的所有记录。
SQL:select * from students
linq:from s in students select s
lambda:students.select(s=>s)
4、查询Score表中成绩在60到80之间的所有记录。
SQL:select * from Score where degree between 60 and 80
linq:from s in Score where s.degree>=60 && s.degree<=80 select s
lambda:Score.where(s=>(s.degree>=60 && s.degree<=80))
5、查询Score表中成绩为85,86或88的记录。
SQL:select * from Score where degree in (85,86,88)
linq:from s in Score where (new decimal[]{85,86,88}).contains(s.degree) select s
lambda:Score.where(s=>(new Decimal[]{85,86,88}.contains(s.degree)))
查询Score表中成绩不是85,86或88的记录。
SQL:select * from Score where degree not in (85,86,88)
linq:from s in Score where !(new decimal[]{85,86,88}).contains(s.degree) select s
lambda:Score.where(s=>!(new Decimal[]{85,86,88}.contains(s.degree)))
6、查询Student表中"95031"班或性别为"女"的同学记录。
SQL:select * from students where class ='95031' or ssex= N'女'
linq:from s in Students where s.class="95031" || s.ssex="女" select s
lambda:Students.where(s=>(s.class="95031"||s.ssex="女"))
7、以Class降序查询Student表的所有记录。
SQL:select * from students order by Class DESC
linq:from s in students orderby s.class Descending select s
lambda:Students.OrderByDescending(s=>s.class)
8、以Cno升序、Degree降序查询Score表的所有记录。
SQL:select * from score order by Cno ASC,Degree DESC
linq:from s in Score orderby s.degree descending orderby s.cno ascending select s
lambda:Score.OrderByDescending(s=>s.degree).OrderBy(s=>s.cno)
9、查询"95031"班的学生人数。
SQL:select count(*) from students where class = '95031'
linq:(from s in Students where s.class="95031" select s).count()
lambda:Students.where(s=>s.class=="95031").Select(s=>s).Count()
10、查询Score表中的最高分的学生学号和课程号。
SQL:select distinct s.Sno,c.Cno from students as s,course as c ,score as sc where s.sno=(select sno from score where degree = (select max(degree) from score)) and c.cno = (select cno from score where degree = (select max(degree) from score))
linq:(from s in Students from c in Courses from sc in Scores let maxDegree = (from sss in Scores select sss.degree).max() let sno = (from ss in Scores where ss.degree == maxDegree select ss.sno).single().ToString() let cno = (from ssss in Scores where ssss.degree == maxDegree select ssss.cno).Single().ToString() where s.sno== sno && c.cno=cno select new{s.sno,c.cno}).Distinct()
11、查询'3-105'号课程的平均分。
SQL:select avg(degree) from score where cno = '3-105'
linq:(from s in scores where s.cno="3-105" select s.degree).average()
lambda:Scores.where(s=>s.cno=="3-105").select(s=>s.degree).average()
12、查询Score表中至少有5名学生选修的并以3开头的课程的平均分数。
select avg(degree) from score where cno like '3%' group by Cno having count(*)>=5
linq:from s in Scores where s.cno.StartsWith("3") group s by s.cno into cc where cc.count()>=5 select cc.average(c=>c.degree)
lambda:Scores.where(s=>s.cno.StartsWith("3")).GroupBy(s=>s.cno).where(cc=>(cc.count()>=5)).select(cc=>cc.average(c=>c.degree))
13、查询最低分大于70,最高分小于90的Sno列。
select sno from score group by sno having min(degree) > 70 and max(degree) < 90
linq:from s in Scores group s by s.sno into ss where ss.min(cc=>cc.degree)>70 && ss.max(cc=>cc.degree)<90 select new {sno=ss.key}
lambda:Scores.GroupBy(s=>s.sno).where(ss=>((ss.Min(cc=>cc.degree)>70)&&(ss.max(cc=>cc.degree)<90))).select(ss=>new{sno=ss.key})
14、查询所有学生的Sname、Cno和Degree列。
select s.sname,sc.cno,sc.degree from student as s,score as sc where s.sno = sc.sno
linq:from s in Students join sc in Scores on s.sno equals sc.sno select new {s.sname,sc.cno,sc.degree}
lambda:Students.join(Scores, s=>s.sno, sc=>sc.sno, (s,sc)=>new{sname=s.name,cno=sc.cno,degree=sc.degree})
15、查询所有学生的Sno、Cname和Degree列。
SQL:select sc.sno,c.cname,sc.degree from course as c,score as sc where c.cno = sc.cno
linq:from c in Courses join sc in Scores on c.cno equals sc.cno select new {sc.sno,c.came,sc.degree}
lambda:Courses.join(Scores,c=>c.no,sc=>sc.cno,(c,sc)=>new{sno=sc.sno,cname=c.cname,degree=sc.degree})
16、查询所有学生的Sname、Cname和Degree列。
SQL:select s.sname,c.cname,sc.degree from student as s,course as c,score as sc where s.sno = sc.sno and c.cno = sc.cno
linq:from s in Students from c in Courses from sc in Scores where s.sno==sc.sno && c.cno==sc.cno select new{s.sname,c.cname,sc.degree}
SQL,Linq,Lambda之间的转换练习的更多相关文章
- SQL,LINQ,Lambda语法对照图(转载)
如果你熟悉SQL语句,当使用LINQ时,会有似曾相识的感觉.但又略有不同.下面是SQL和LINQ,Lambda语法对照图 SQL LINQ Lambda SELECT * FROM HumanReso ...
- C# ORM中Dto Linq Expression 和 数据库Model Linq Expression之间的转换
今天在百度知道中看到一个问题,研究了一会便回答了: http://zhidao.baidu.com/question/920461189016484459.html 如何使dto linq 表达式转换 ...
- sql linq lambda 对比
. 查询Student表中的所有记录的Sname.Ssex和Class列. select sname,ssex,class from student Linq: from s in Students ...
- 构造复杂Lambda困惑之学会用LinqPad和Linqer实现Sql 和 Lambda之间的互转
一:linq的话我们可能会遇到两个问题: 1. 我们的linq出现性能低下的时候,如果优化???? 我们写的linq所生成的sql是无法控制的... (要做性能优化,必须预先知道sql会生成啥样的?? ...
- SQL/LINQ/Lamda 写法[转发]
SQL LINQ Lambda SELECT * FROM HumanResources.Employee from e in Employees select e Employees .Sele ...
- SQL Linq lamda区别
SQL LINQ Lambda SELECT * FROM HumanResources.Employee from e in Employees select e Employees .Sele ...
- SQL/LINQ/Lamda
SQL LINQ Lambda SELECT * FROM HumanResources.Employee from e in Employees select e Employees .Sele ...
- linq中查询列表的使用及iqueryable和list集合之间的转换
linq中查询列表的使用及iqueryable和list集合之间的转换 比如要查询一个货架集合,但是只需要其id和name即可,可以用以下方法:先写一个model类:CatalogModel(注意该类 ...
- java.util.Date 与 java.sql.Date 之间的转换
SimpleDateFormat sdf = new SimpleDateFormat("yy-MM-dd HH:mm:ss"); String dateStr = sdf.for ...
随机推荐
- React-Router学习整理
欢迎大家指导与讨论 : ) 一.前言 本文摘要:react-router的基本用法,动画效果与路由,路由权限控制,路由离开确认,根据路由切分的按需加载,路由组件的属性.本文是笔者在学习时整理的笔记,由 ...
- Python学习Day2笔记(集合和文件操作)
1.集合的使用 列表是有序的可包含重复内容的 集合是无序的不可包含重复内容的 1) 集合关系测试 #列表去重list_1=[1,4,5,6,7,8,9,7,5,4,23,2] #有重复数据 list_ ...
- android开发环境搭建(ubuntu15.04+jdk8+eclipse+android sdk)
开始学习android开发,首先对其环境对搭建比较重要.平台可以选择window/linux/mac等,这里,我选择ubuntu系统,方法比较原始,当然也可以直接用google提供的android s ...
- 【原创】日志文件清理工具V1.0
最近公司的系统服务器经常出现磁盘空间不足的情况,登陆服务器发现原来是公司的HR系统日志造成的(插个话题:我们公司的HR系统都实施两年多了还没上线,且不说软件功能如何,服务太TMD差劲了,更可气的是软件 ...
- sql语句 in的教训
如果子查询条件数据量特别大的话,千万不要用子查询.
- 让C#可以像Javascript一样操作Json
Json的简介 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了 ...
- RapidJSON 代码剖析(四):优化 Grisu
我曾经在知乎的一个答案里谈及到 V8 引擎里实现了 Grisu 算法,我先引用该文的内容简单介绍 Grisu.然后,再谈及 RapidJSON 对它做了的几个底层优化. (配图中的<Grisù& ...
- 使用apache ftpserver搭建ftp服务器
作为一个javaer,遇到任何问题,先查一下java中的解决方案.地球上的许多事情,在java中都能找到完美的解决方案.之前搭建ftp服务器使用的是vsftpd,现在可以把它卸掉了,它以服务的形式运行 ...
- [HTTP Protocol] 200 OK (from cache)和304 Not Modified
含义 200 OK (from cache)直接从缓存中获取的内容并未请求服务器 304 Not Modified 请求服务器并和服务器比较 If-Modified-Since,若文件未改变,服务器返 ...
- 使用antd UI组件有感
公司使用的的react.js的版本提14.7的,JS版本使用的是ES6语法,因此在使用antd过程中,有些许不愉快的记录,分享给大家,一起学习: 如果是react 14.7版本时,使用getField ...