大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇“SQL查询怎么给表起别名”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“SQL查询怎么给表起别名”文章吧。
创新互联公司是一家集网站建设,迎泽企业网站建设,迎泽品牌网站建设,网站定制,迎泽网站建设报价,网络营销,网络优化,迎泽网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
但是注意如果操作的数据库是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查询怎么给表起别名”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注创新互联行业资讯频道。