1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 | SQL、LINQ、Lambda 三种用法 颜色注释: SQL LinqToSql Lambda QA 1、 查询Student表中的所有记录的Sname、Ssex和Class列。 select sname,ssex, class from student 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列。 select distinct depart from teacher Linq: from t in Teachers.Distinct() select t.DEPART Lambda: Teachers.Distinct().Select( t => t.DEPART) 3、 查询Student表的所有记录。 select * from student Linq: from s in Students select s Lambda: Students.Select( s => s) 4、 查询Score表中成绩在60到80之间的所有记录。 select * from score where degree between 60 and 80 Linq: from s in Scores where s.DEGREE >= 60 && s.DEGREE < 80 select s Lambda: Scores.Where( s => ( s.DEGREE >= 60 && s.DEGREE < 80 ) ) 5、 查询Score表中成绩为85,86或88的记录。 select * from score where degree in (85,86,88) Linq: In from s in Scores where ( new decimal []{85,86,88} ).Contains(s.DEGREE) select s Lambda: Scores.Where( s => new Decimal[] {85,86,88}.Contains(s.DEGREE)) Not in from s in Scores where !( new decimal []{85,86,88} ).Contains(s.DEGREE) select s Lambda: Scores.Where( s => !( new Decimal[]{85,86,88}.Contains(s.DEGREE))) Any()应用:双表进行Any时,必须是主键为(String) CustomerDemographics CustomerTypeID(String) CustomerCustomerDemos (CustomerID CustomerTypeID) (String) 一个主键与二个主建进行Any(或者是一对一关键进行Any) 不可,以二个主键于与一个主键进行Any from e in CustomerDemographics where !e.CustomerCustomerDemos.Any() select e from c in Categories where !c.Products.Any() select c 6、 查询Student表中 "95031" 班或性别为 "女" 的同学记录。 select * from student where class = '95031' or ssex= N '女' Linq: from s in Students where s.CLASS == "95031" || s.CLASS == "女" select s Lambda: Students.Where(s => ( s.CLASS == "95031" || s.CLASS == "女" )) 7、 以Class降序查询Student表的所有记录。 select * from student 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表的所有记录。 select * from score order by Cno ASC,Degree DESC Linq:(这里Cno ASC在linq中要写在最外面) from s in Scores orderby s.DEGREE descending orderby s.CNO ascending select s Lambda: Scores.OrderByDescending( s => s.DEGREE) .OrderBy( s => s.CNO) 9、 查询 "95031" 班的学生人数。 select count(*) from student 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表中的最高分的学生学号和课程号。 select distinct s.Sno,c.Cno from student 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() 操作时问题?执行时报错: where s.SNO == sno(这行报出来的) 运算符 "==" 无法应用于 "string" 和 "System.Linq.IQueryable<string>" 类型的操作数 解决: 原: let sno = ( from ss in Scores where ss.DEGREE == maxDegree select ss.SNO).ToString() Queryable().Single()返回序列的唯一元素;如果该序列并非恰好包含一个元素,则会引发异常。 解: let sno = ( from ss in Scores where ss.DEGREE == maxDegree select ss.SNO).Single().ToString() 11、查询 '3-105' 号课程的平均分。 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) ) Linq: SqlMethod like也可以这样写: s.CNO.StartsWith( "3" ) or SqlMethods.Like(s.CNO, "%3" ) 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.SNAME, CNO = sc.CNO, DEGREE = sc.DEGREE }) 15、查询所有学生的Sno、Cname和Degree列。 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.CNAME,sc.DEGREE } Lambda: Courses.Join ( Scores, c => c.CNO, sc => sc.CNO, (c, sc) => new { SNO = sc.SNO, CNAME = c.CNAME, DEGREE = sc.DEGREE }) 16、查询所有学生的Sname、Cname和Degree列。 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 } |
转自:http://Www.CnBlogs.Com/WebEnh/
如果想下次快速找到我,记得点下面的关注哦!
本博客Android APP 下载 |
![]() |
支持我们就给我们点打赏 |
![]() |
支付宝打赏 支付宝扫一扫二维码 |
![]() |
微信打赏 微信扫一扫二维码 |
![]() |
如果想下次快速找到我,记得点下面的关注哦!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!