你不知道的update语句的用法
本文导语: 本节内容: update语句的另类用法。 sql中的update语句,很简单的,格式为: 代码示例: update table set column=expression [where search_condition 。 但真的update语句只能如此吗?它的精髓它的原理是什么? 通过例子来说明: 假设有一张...
本节内容:
update语句的另类用法。
sql中的update语句,很简单的,格式为:
。
但真的update语句只能如此吗?它的精髓它的原理是什么?
通过例子来说明:
假设有一张成绩表,只有两个字段,姓名和成绩。
怎样用一个sql语句查询出某个学生的姓名,成绩以及在表中的排名?
如何实现这个sql查询?
昨天去面试时遇到一个这样的问题:
有一张成绩表,只有两个字段,姓名和成绩。怎样用一个sql语句查询出某个学生的姓名,成绩以及在表中的排名?
一时间我也想不出具体实现,我就提了两种思路:一种是通过join关联一个查询出他排名的sql语句;一种是通过group by来实现。
回答得连自己都觉得有点心虚。请问大家如何实现呢?
假设:表名字为Course,两个字段分别为name和score
结果可以去那里看。现在改改问题,假设这张成绩表有三个字段,姓名、成绩和排名,现在只有姓名和成绩有值,怎样将他们的排名更新上去呢?
有朋友可能会提出类似解决方案:先还是用查询语句查询出来,然后通过游标更新排名。
有没有更好的解决方案呢?当然是有的,答案就是用update语句。
update 成绩表 set 排名=(select count(*)+1 from 成绩表 where a.成绩