SQL查询怎么给表起别名

71次阅读
没有评论

共计 1402 个字符,预计需要花费 4 分钟才能阅读完成。

这篇“SQL 查询怎么给表起别名”文章的知识点大部分人都不太理解,所以丸趣 TV 小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“SQL 查询怎么给表起别名”文章吧。

可以通过空格或者 as 给表起别名

但是注意如果操作的数据库是 Oracle 的话,只能使用空格,as 不符合 Oracle 的语法。

举个栗子

简单查询中使用别名

select *
from student s
where s.id =  10

在简单的查询中使用别名,一般没有特别需要注意的地方,要做的操作少

复杂查询中使用别名

题目概要:有三个表格,student(sno,sname,ssex,sbirthday,class)

score(sno,cno,degree)

course(cno,cname,tno)

查询选修“3-105”课程的成绩高于“109”号同学成绩的所有同学的记录。

答案:

select *
 from (select s.sno,s.sname,s.ssex,s.sbirthday,s.class, sc.degree,c.cno,c.cname,c.tno from student s , course c ,score sc where s.sno = sc.sno and c.cno = sc.cno) ss
 where ss.cno =  3-105  and ss.degree  ( select degree from score where sno =  109  and cno =  3-105

可以看到,为了方便操作,我们重新定义了一个表格 ss,这个表格是一个大表格同时包含了,以上三个表中的内容。但是要注意以下几点,不然容易出错

要全部显示新定义表格的值时,不能直接使用 *

比如声明的答案中如果改为

select *
 from (select * from student s , course c ,score sc where s.sno = sc.sno and c.cno = sc.cno) ss
 where ss.cno =  3-105  and ss.degree  ( select degree from score where sno =  109  and cno =  3-105

命令行会显示列未明确定义,因为我们要现在指定的列作为一个新的表,但是有些列的列名是重复的,我们需要指定其中的一个。

在嵌套查询语句中无法使用新创的表,因为嵌套查询里面的代码是一个完整的执行段,会从头开始运行?反正在里面调用会报错

select *
 from (select * from student s , course c ,score sc where s.sno = sc.sno and c.cno = sc.cno) ss
 where ss.cno =  3-105  and ss.degree  ( select degree from ss where sno =  109  and cno =  3-105

这段 SQL 里面在 where 里面的子查询使用了 ss 新表,编译会显示表或视图不存在错误。

以上就是关于“SQL 查询怎么给表起别名”这篇文章的内容,相信大家都有了一定的了解,希望丸趣 TV 小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注丸趣 TV 行业资讯频道。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计1402字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)