sql查询给表起别名要点小结(涉及嵌套查询)

 更新时间:2022年09月06日 09:24:17   作者:foas9we  
通过使用 SQL,可以为表名称或列名称指定别名,下面这篇文章主要给大家介绍了关于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查询给表起别名要点(涉及嵌套查询)的文章就介绍到这了,更多相关sql查询给表起别名内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Oracle数据库实现建表、查询方式

    Oracle数据库实现建表、查询方式

    这篇文章主要介绍了Oracle数据库实现建表、查询方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2007-02-02
  • Oracle/SQL中TO_DATE函数详细实例解析

    Oracle/SQL中TO_DATE函数详细实例解析

    Oracle to_date()函数用于日期转换,下面这篇文章主要给大家介绍了关于Oracle/SQL中TO_DATE函数的相关资料,文中通过代码介绍的非常详细,对大家学习或者使用oracle具有一定的参考解决价值,需要的朋友可以参考下
    2024-06-06
  • Oracle中实现MySQL show index from table命令SQL脚本分享

    Oracle中实现MySQL show index from table命令SQL脚本分享

    这篇文章主要介绍了Oracle中实现MySQL show index from table命令SQL脚本分享,本文只是模拟了Mysql中的show index from table命令,需要的朋友可以参考下
    2014-10-10
  • Oracle字段根据逗号分割查询数据的方法

    Oracle字段根据逗号分割查询数据的方法

    项目需求是这样的表里的某个字段存储的值是以逗号分隔开来的,要求根据分隔的每一个值都能查出来数据,但是不能使用like查询。这篇文章主要介绍了Oracle字段根据逗号分割查询数据,需要的朋友可以参考下
    2018-08-08
  • 随机获取oracle数据库中的任意一行数据(rownum)示例介绍

    随机获取oracle数据库中的任意一行数据(rownum)示例介绍

    对于rownum来说它是oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数,且rownum不能以任何表的名称作为前缀
    2014-07-07
  • oracle数据库tns配置方法详解

    oracle数据库tns配置方法详解

    TNS是Oracle Net的一部分,专门用来管理和配置Oracle数据库和客户端连接的一个工具,在大多数情况下客户端和数据库要通讯,必须配置TNS,下面看一如何配置它吧
    2013-12-12
  • 基于oracle expdp命令的使用详解

    基于oracle expdp命令的使用详解

    本篇文章是对oracle expdp命令的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 使用MySQL语句来查询Apache服务器日志的方法

    使用MySQL语句来查询Apache服务器日志的方法

    这篇文章主要介绍了使用MySQL语句来查询Apache服务器日志的方法,五个实例均基于Linux系统进行演示,需要的朋友可以参考下
    2015-06-06
  • Oracle中instr函数使用方法

    Oracle中instr函数使用方法

    在Oracle/PLSQL中,instr函数返回要截取的字符串在源字符串中的位置。只检索一次,就是说从字符的开始到字符的结尾就结束
    2012-11-11
  • Oracle在Mybatis中SQL语句的配置方法

    Oracle在Mybatis中SQL语句的配置方法

    这篇文章主要介绍了Oracle在Mybatis中SQL语句的配置 ,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03

最新评论