博主在工作中,常常需要使用sql语句来进行查询,总结发现,灵活使用这几个要点,就可以应付大部分简单情况。

一.连接:根据两个或多个表中的列之间的关系,从这些表中查询数据。

  • JOIN或INNER JOIN: 返回左表和右表中相互匹配的行
  • LEFT JOIN: 返回左表和右表中相互匹配的行,及左表中不相匹配的行
  • RIGHT JOIN: 返回左表和右表中相互匹配的行,及右表中不相匹配的行
  • FULL JOIN或FULL OUTER JOIN: 返回左表和右表中相互匹配的行,及不相匹配的行
  • 应用举例
  • 在一些题目中没有明确的暗示情况下,使用哪一种连接方式都可以;
  • 也有一些情况,只能使用特定的连接方式。

1.join/inner join

必须使用inner join的情况

  --查询所有未讲课的教师的Tname和Depart.
select TNAME,DEPART
from TEACHER
where TNO not in(select TEACHER.TNO from COURSE inner join
TEACHER on COURSE.TNO=TEACHER.TNO)
--或者使用 Except
select TNAME,DEPART from TEACHER
except
select TNAME,DEPART from COURSE join TEACHER on COURSE.TNO=TEACHER.TNO

上面的sql语句中的“select TEACHER.TNO from COURSE inner join TEACHER on COURSE.TNO=TEACHER.TNO”中,只能使用inner join,使用left join、right join、full join都是错误的。

2.left join和right join

使用了left join 的情况,调换一下表的位置,就可以用right join替换;反之亦然。

 --查询所有学生的Sname、Cname和Degree列。
select SNAME,CNAME,DEGREE
from STUDENT left join SCORE on STUDENT.SNO=SCORE.SNO
left join COURSE on SCORE.CNO=COURSE.CNO

也可以写成

 select SNAME,CNAME,DEGREE
from score right join STUDENT on STUDENT.SNO=SCORE.SNO
right join COURSE on SCORE.CNO=COURSE.CNO

3.使用full join的情况较少,暂时还没有用到。

二、嵌套

在sql语言中,一个select-from-where语句成为一个查询块。

将一个查询块嵌套在另一个查询块的where子句或having短语的条件中的查询成为嵌套查询。

SQL语言允许多层嵌套查询,但要注意的是,子查询的select语句中不能使用order 不要子句,order by子句只能对最终查询结果排序。

当掌握了sql语句的执行顺序后,就会对这个限制的原因有更深刻的理解。

举例

子查询在where子句中

 --查询成绩高于学号为“109”、课程号为“3-105”的成绩的所有记录。
select * from SCORE where DEGREE>(select DEGREE from SCORE where SNO='' and CNO='3-105')

三、子查询

上层的查询块称为外层查询或者父查询,下层查询块称为内层查询或者子查询。

子查询的位置可以很灵活,掌握这一点,感觉sql学习就有了很大的进展。

1.子查询可以放到where子句或having短语的条件中,这就是我们上面所介绍的嵌套查询

2.子查询可以出现在from子句中,这时子查询生成的临时派生表,称为主查询的查询对象

 --查询所有选修了1号课程的学生姓名  (当然也可以使用嵌套查询)
select Sname from Student,(select * from SC where cno='') SC1 where Student.sno=SC1.sno

3.子查询可以嵌套在INSERT语句中用以生成要插入的批量数据

 --对每个系,求学生的平均年龄,再把结果插入Dept_age(Sdept,Avg_age)中
insert into Dept_age(Sdept,Avg_age)
select Sdept.AVG(Sage)
from Student
group by Sdept

要点总结

1.连接:inner join、right join、left join 、full join

2.嵌套:将一个查询块嵌套在另一个查询块的where子句或having短语的条件中

3.子查询的位置可以很灵活

常用sql语法初级的更多相关文章

  1. oracle 常用SQL语法手册

    Select 用途: 从指定表中取出指定的列的数据 语法: SELECT column_name(s) FROM table_name 解释: 从数据库中选取资料列,并允许从一或多个资料表中,选取一或 ...

  2. 常用SQL语法

    1.替換A表中B字段中第二个字符 ,), 2.根据 Score 字段 排序 并分页 * from (select row_number() over(order by Score DESC) as r ...

  3. mysql常用sql语法

    一.创建主键的三种方式 1. CREATE TABLE user( uid INT PRIMARY KEY, uname VARCHAR(10), address VARCHAR(20) ) 2. C ...

  4. SQL语法之初级增删改查

    SQL语法之初级增删改查 1.增 1.1插入单行 INSERT INTO [表名](列名) VALUES(列值) 语法如下: INSERT INTO bsp_Nproductclass(guid,pi ...

  5. 【知识库】-数据库_MySQL常用SQL语句语法大全示例

    简书作者:seay 文章出处: 关系数据库常用SQL语句语法大全 Learn [已经过测试校验] 一.创建数据库 二.创建表 三.删除表 四.清空表 五.修改表 六.SQL查询语句 七.SQL插入语句 ...

  6. HIVE常用SQL语句及语法

    HIVE建内部表语句 create table dll102.sougou (id string,pwd string,name string,count int,seqno int,address ...

  7. 值得注意的ibatis动态sql语法格式

    一.Ibatis常用动态sql语法,简单粗暴用一例子 <select id="iBatisSelectList" parameterClass="java.util ...

  8. oracle(sql)基础篇系列(一)——基础select语句、常用sql函数、组函数、分组函数

        花点时间整理下sql基础,温故而知新.文章的demo来自oracle自带的dept,emp,salgrade三张表.解锁scott用户,使用scott用户登录就可以看到自带的表. #使用ora ...

  9. 常用SQL[ORACLE]

        1.常用系统函数 2.常用sql语句 3.一些定义和关键字 4.需要注意点   1.常用系统函数 ↑ --decode decode(column,if_value,value,elseif_ ...

随机推荐

  1. 《剑指offer》第二十九题(顺时针打印矩阵)

    // 面试题29:顺时针打印矩阵 // 题目:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字. #include <iostream> void PrintMatrixInC ...

  2. 怎么运行cocos2dx 3.x simulator?

    1.simulator的好处是: 快速切换分辨率:F5快速重新启动项目: 这对于脚本语言来说都是很方便快捷的. 2.涉及到显示参数的文件有两个: ①lang,这个是菜单的语言文件,如果没有这个文件的话 ...

  3. C#异常信息获取

    try { ; / i; } catch (Exception ex) { /** * 1.异常消息 * 2.异常模块名称 * 3.异常方法名称 * 4.异常行号 */ String str = &q ...

  4. ln软连接

    ln软连接 ln -s 源目录/文件    目标目录/文件 例如,有个应用 /var/www/html/webapp,下面有个logs日志文件夹,想吧  webapp/logs日志文件夹链到/home ...

  5. python-day30--粘包

    一. 什么是粘包 1.须知:只有TCP有粘包现象,UDP永远不会粘包 2.所谓粘包问题主要还是因为接收方不知道消息之间的界限,不知道一次性提取多少字节的数据所造成的. 二.两种情况下会发生粘包. 1. ...

  6. [Spring Boot] 使用多个Servlet

    当使用Spring boot的嵌入式servlet容器时,可以通过Spring bean或扫描Servlet组件的方式注册Servlet.Filter和Servlet规范的所有监听器(例如HttpSe ...

  7. Syntax error: Bad for loop variable解决办法

    从 ubuntu 6.10 开始,ubuntu 就将先前默认的bash shell 更换成了dash shell:其表现为 /bin/sh 链接倒了/bin/dash而不是传统的/bin/bash. ...

  8. Shell脚本的学习(一)

    Shell脚本的学习(一) 一)代码式shell脚本简介 1.下载 Xshell 5 建一个文件夹 mkdri home/data ; 1)查看一个在data里建一个1.sh 查看是否建立成功. 2) ...

  9. $digest already in progress 解决办法——续

    什么时候手动调用$apply()方法? 如果AngularJS总是将我们的代码wrap到一个function中并传入$apply(),以此来开始一轮$digest循环,那么什么时候才需要我们手动地调用 ...

  10. Python中变量、赋值、浅拷贝、深拷贝

    https://www.cnblogs.com/LetMe/p/6724555.html 在理解浅拷贝和深拷贝之前,首先要理解学习一下变量在Python中是怎样存储的: 变量的类型是分值引用与地址引用 ...