打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Sql子查询
Sql子查询 收藏
   Sql子查询即是当一个查询语句嵌套在另一个查询语句的查询条件中时叫做子查询也叫做嵌套子查询。根据子查询的返回结果不同,子查询又可分为单行子查询,多行子查询与多列子查询。现在如下三类子查询作说明,并假设有如下四个表记录学生选修课的成绩: Student(stId, stName); course(coId,coName); teacher(teId, teName); score(stId, teId, coId, score) 其中学生可以有多门选修课,一个老师也可以教多门课程。
   1> 单行子查询
   单行子查询是指子查询的返回结果只有一行数据。当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较。
   例子:查询名叫Kaka的学生的所有成绩 sql> Select score from score where stId=(select stId from Student where stName='Kaka');
   2> 多行子查询
   多行子查询即是子查询的返回结果是多行数据。当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。其中,IN的含义是匹配子查询结果中的任一个值即可,ALL则必须要符合子查询的所有值才可,ANY要符合子查询结果的任何一个值即可。而且须注意ALL 和ANY 操作符不能单独使用,而只能与单行比较符(=、>、< 、>= 、<= 、<>)结合使用。
   多行子查询使用IN操作符号例子:查询选修了老师名叫Rona(假设唯一)的学生名字 sql> select stName from Student where stId in(selectdistinct stId from score where teId=(select teId from teacher where teName='Rona'));
   多行子查询使用ALL操作符号例子:查询有一门以上的成绩高于Kaka的最高成绩的学生的名字 sql> select stName from Student where stId in(select distinct stId from score where score >all(select score from score where stId=(select stId from Student where stName= 'Kaka') ));
   多行子查询使用ANY操作符号例子:查询有一门以上的成绩高于Kaka的任何一门成绩的学生的名字 sql> select stName from Student where stId in(select distinct stId from score where score >any(select score from score where stId=(select stId from Student where stName='Kaka')));
   3> 多列子查询
   以上的单行与多行子查询的返回结果都是单列数据,而这个多例子查询顾名义当然就是返回结果是多列的数据。而多列子查询当然也可以返回单行或是多行的多列数据,当是单行多列的子查询时,主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较;当是多行多列子查询时,主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。
   具体跟以上两个并无太多不同,只是比较的不是单列而是多列数据而已。
 
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/rboyxxx/archive/2009/08/17/4455757.aspx
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
SQL中的注释语句
SQL Server——SQL Server存储过程与exec简单使用
MySQL 子查询语句
第8章数据查询
KAKA
12.2 删除表中的数据 - 《精通SQL——结构化查询语言详解》 - 免费试读 - bo...
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服