你不知道的update语句的用法

发布时间:2019-09-22编辑:脚本学堂
本文介绍下,不为大家所熟悉的update语句的一些用法,感兴趣的朋友可以参考下。

本节内容:
update语句的另类用法。

sql中的update语句,很简单的,格式为:

复制代码 代码示例:
update table set column=expression  [where search_condition

但真的update语句只能如此吗?它的精髓它的原理是什么?

通过例子来说明:
假设有一张成绩表,只有两个字段,姓名和成绩。
怎样用一个sql语句查询出某个学生的姓名,成绩以及在表中的排名?

如何实现这个sql查询?

昨天去面试时遇到一个这样的问题:
有一张成绩表,只有两个字段,姓名和成绩。怎样用一个sql语句查询出某个学生的姓名,成绩以及在表中的排名?

一时间我也想不出具体实现,我就提了两种思路:一种是通过join关联一个查询出他排名的sql语句;一种是通过group by来实现。

回答得连自己都觉得有点心虚。请问大家如何实现呢?

假设:表名字为Course,两个字段分别为name和score

结果可以去那里看。现在改改问题,假设这张成绩表有三个字段,姓名、成绩和排名,现在只有姓名和成绩有值,怎样将他们的排名更新上去呢?

有朋友可能会提出类似解决方案:先还是用查询语句查询出来,然后通过游标更新排名。
有没有更好的解决方案呢?当然是有的,答案就是用update语句。
 
update 成绩表 set 排名=(select count(*)+1 from 成绩表 where a.成绩<成绩)
from 成绩表 a

可以看到,只用一个语句就实现了。同时我们也可以发现它跟我们平常写的update语句不同,多了from。

其实update语句的原理和select语句很类似,完整的update语句应该是update table set column=expression from table [where search_condition] ,可见后面的一截完全就是个查询语句。

当update的table和查询的table(也就是from后面的table)完全一致的时候则可以省略,写成最常见的update table set column=expression [where search_condition] 。