0.实验数据

表1.course表

表2.student表

表3.sc表

1.SQL连接

  • 内连接

      • select * from student,sc where student.sno=sc.sno;//相等连接,也可以用!=,<=等来连接
      • select * from student inner join sc using(sno);
      • select * from student inner join sc on student.sno=sc.sno;  
  • 外连接
      • 左外连接: select * from student left join using(sno);
      • 右外连接: select * from student right join using(sno);
      • 全连接:mysql 貌似不支持,不过可以使用union进行间接实现
  • 笛卡尔积
      • select * from student,sc; 
  • 自连接

      • student表自己连接自己
      • select * from student s1,student s2 where s1.sno=s2.sno;//为表创建了两个别名    

2.子查询

  • 子查询的分类
  • 1.嵌套子查询----先执行子查询把结果返回给,父查询
  • 2.相关联子查询--父查询把数据按照行一次传递给子查询,子查询判定是否满足子查询条件后,返回boolean值给父查询,父查询决定是否保留这条数据,直到所有的数据处理完毕。(比较难)
  • 嵌套子查询
  • 1.Books表,列:ClassID,bookName,publish,price
  • Q1:查询所有价格高于平均价格的图书名,出版社和价格
  • select bookName,publish,price from Books where price>(select avg(price) from books);
  • 2.sc表,列:sno(学号),cno(课程号),grade
  • Q1:查询只有一人选修的课程
  • select cno from sc group by cno having count(*)=1;
  • 相关联子查询
  • 1.sc表,列:sno(学号),cno(课程号),grade
  • Q1:查询只有一人选修的课程(相关子查询-理解为没有和别人选同一门的课程)
  • select cno from sc scx where cno not in (select cno from sc where sno!=scx.sno);
  • 2.sc表,列:sno(学号),cno(课程号),grade
  • Q2:查询每个科目的前两名

  • select * from sc where (select count(*) from sc scx where sc.cno=cno and grade>sc.grade)<2 order by cno,sno;  
  • In与Exists选择
  • 1.select * from A where id in (select id from B)
  • 当B表的数据集必须小于A表的数据集时,用in优于exists
  • 2.select * from A where exists (select 1 from B where B.id = A.id)
  • 当A表的数据集系小于B表的数据集时,用exists优于in。

参考文献

http://blog.csdn.net/ghyg525/article/details/28272007

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px "Courier New"; color: #006699; background-color: #ffffff }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px "Courier New"; background-color: #ffffff }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma }
span.s1 { }
span.s2 { color: #000000 }
span.s3 { color: #808080 }
span.s4 { color: #006699 }
table.t1 { border-collapse: collapse }
td.td1 { width: 627.5px }
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px "Courier New"; background-color: #ffffff }
span.s1 { color: #006699 }
span.s2 { }
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma }
span.s1 { }

2.SQL语言进阶的更多相关文章

  1. SQL Server 进阶 01 数据库的设计

    SQL Server 进阶 01 数据库的设计 本篇目录 课程内容回顾及介绍 为什么需要规范的数据库设计 设计数据库的步骤 绘制E-R(实体-关系)图 实体-关系模型 如何将E-R图转换为表 数据规范 ...

  2. SODBASE CEP学习(四)续:类SQL语言EPL与Storm或jStorm集成-使用分布式缓存

    流式计算在一些情况下会用到分布式缓存,从而实现(1)想把统计或计算结果保存在分布缓存中.供其他模块或其他系统调用. (2)某一滑动时间窗体上计数.比如实时统计1小时每一个Cookie的訪问量.实时统计 ...

  3. 2016 - 3 - 12 SQLite的学习之SQL语言入门

    1.SQL语句的特点: 1.1 不区分大小写 1.2 每条语句以;结尾 2.SQL语句中常用关键字: select,insert,update,from,create,where,desc,order ...

  4. SQL 语言 - 数据库系统原理

    SQL 发展历程 从 1970 年美国 IBM 研究中心的 E.F.Codd 发表论文到 1974 年 Boyce 和 Chamberlin 把 SQUARE 语言改为 SEQUEL 语言,到现在的 ...

  5. SQL语言

    SQL语言的分类:DDL DML DQL DCL SQL中的操作无非就是(增删改查) DDL:Data Query Language,数据查询语言! 主要是用来定义和维护数据库的各种操作对象,比如库. ...

  6. SQL语言分类

    SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML, 数据定义语言DDL,数据控制语言DCL. 1 数据查询语言DQL数据查询语言DQL基本结构是由SELECT子句,FROM子句,WHER ...

  7. SQL语言概述

    功能概述 DDL,数据库定义语言,创建,修改,删除数据库,表,视图,索引,约束条件等 DML,数据库操纵语言,对数据库中的数据进行增,删,改,查 DCL,数据库定义语言,对数据库总数据的访问设置权限 ...

  8. MySQL中的SQL语言

    从功能上划分,SQL 语言可以分为DDL,DML和DCL三大类.1. DDL(Data Definition Language)数据定义语言,用于定义和管理 SQL 数据库中的所有对象的语言 :CRE ...

  9. atitit.java解析sql语言解析器解释器的实现

    atitit.java解析sql语言解析器解释器的实现 1. 解析sql的本质:实现一个4gl dsl编程语言的编译器 1 2. 解析sql的主要的流程,词法分析,而后进行语法分析,语义分析,构建sq ...

随机推荐

  1. iOS开发系统版本适配(未完待续。。。)

    1.iOS9引入了新特性App Transport Security (ATS).新特性要求App内访问的网络必须使用HTTPS协议:iOS9系统发送的网络请求将统一使用TLS 1.2 SSL.采用T ...

  2. [题解]bzoj 1861 Book 书架 - Splay

    1861: [Zjoi2006]Book 书架 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 1396  Solved: 803[Submit][Stat ...

  3. sql数据库恢复 文件丢失误删除 误格式化置疑报错修复 数据库置疑修复总结/SQL SERVER 2000/2005/2008/2008R2

    数据库置疑的原因会有多种多样,不同的问题采用的步骤也会有所不同,以下的步骤不能适用所有的情况,但包括了一些基本的步骤. 数据库置疑是指数据库内部处于不一致的状态,很有可能会有数据丢失.我们推荐您从做数 ...

  4. SQL Select结果增加自增自段(网转)

    http://www.cnblogs.com/haver/archive/2011/07/14/2106349.html/* 方法一*/ SELECT 序号= (SELECT COUNT(客户编号) ...

  5. eclipse中集成svn maven开发手册---创建提分支

    开发时,需要拉取分支进行修改等操作 右键项目,选择team->分支/标记 输入创建分支地址 注意: 1,创建分支路径时,最后一层文件名称为项目的名称 2,点击浏览按钮可能会出现无法选择,且ecl ...

  6. Sublime text追踪函数插件

    Sublime Text2/3怎样在Ubuntu中配置CTags插件 | 浏览:1278 | 更新:2014-03-05 10:34 1 2 3 4 5 6 7 分步阅读 本文详解在Ubuntu Li ...

  7. Java读取其他jar包里的配置文件

    最近要做个东西,需要自己控制数据库的事物,项目封装的框架,实在是提不起去阅读的兴趣, 就想直接去读框架的底层实现里面的数据连接的配置文件(如:Url,port,username,password等), ...

  8. iOS 8 之 新特性

    1. 沙盒间共享数据 2. Metal 3D绘图,据说10倍速,替代了OpenGL 3. AppStore 可视频预览

  9. --@angularJS--指令之单个点击展开demo

    1.expander.html: <!DOCTYPE HTML><html ng-app="app"><head>    <title&g ...

  10. MonthCalendar控件

    MonthCalendar控件  功能,直接显示月历,