SQL概述

  SQL发展

  SQL特点

  SQL查询基本概念

单表查询

  投影查询

1.查询指定列:

SELECT 列名1,列名2,列名3,.....FROM  Table_Name;

#查询全部列:
SELECT * FROM Table_Name; #查询某一张表的全部列
SELECT Table_Name_A.*,列名1,列名2,列名3,.....FROM  Table_Name_A,Table_Name_B;

2.消除指定元组:

SELECT DISTINCT  列名  FROM  Table_Name;

  选择查询

比较运算:>,>=.<,<=,=,<>(或者!=)

范围查询:BETWEEN....AND

SELECT studentNO,courseNO,score  from score
where score BETWEEN 80 AND 90;

集合查询:IN

SELECT studentNO,courseNO,score  from score
where courseNo IN('','002,'005');

空值查询:IS   NULL

SELECT * from Student where studentNO  IS  NULL;

字符匹配查询:LIKE   ‘%some char%’,LIKE   ‘_some char_’

下划线_代表匹配一个字符:

SELECT * from Student where studentName LIKE ‘%some char%’;

百分号%代表匹配多个字符:

SELECT * from Student where studentName LIKE ‘_some char_’;

ESCAPE '\'表示\为换码字符,这样紧跟在\符号后面的_就不是通配符了,而是普通用户要查询的符号

SELECT * from Student where studentName LIKE ‘_some char\_’  ESCAPE  '\';

逻辑查询:AND  ,OR    ,NOT

SELECT * FROM student where studentName=‘mikey’  AND  studentNo=2018;
SELECT * FROM student where studentName=‘mikey’  or  studentName=‘LEO' ;
SELECT * FROM student where studentName!=‘mikey’ ;

  排序运算

语法:ORDER  BY  <表达式1>[ASC|DESC],<表达式1>[ASC|DESC],<表达式1>[ASC|DESC].............

ASC:升序(省缺)

DESC:降序

表达式1如果不能判断排序,则推到表达式2

SELECT * FROM STUDENT GROUP BY studentNo;
SELECT * FROM STUDENT GROUP BY studentNo DESC;

  查询表

SELECT studentNo,studentName,birthday from(SELECT * from Student Where sex='女') AS a  where year(birthday)=1999;

  聚合查询

count([DISTINCT|ALL] { *|<列名>});统计关系的元组(记录)个数或者一列中值的个数

sum([DISTINCT|ALL] {<列名>});统计一列中值的总和(此列必须为数值类型)

avg([DISTINCT|ALL] {<列名>});统计一列中值的平均值(此列必须为数值类型)

max([DISTINCT|ALL] {<列名>});统计一列中值的最大值

min([DISTINCT|ALL] {<列名>});统计一列中值的最小值

getdate():获取当前日期时间

year(日期):获取当前日期年份

连接查询

  等值与非等值连接

WHERE [表1.]<属性名1><比较运算符>[表2.]<属性名2>

    [<逻辑运算符>]

    [表3.]<属性名3><比较运算符>[表4.]<属性名4>

比较运算符:>,>=.<,<=,=,<>(或者!=)

WHERE 子句:作用于整个查询对象,对元组过滤

HAVING 子句:仅作用于分组,对分组进行过滤

  自表连接

自己对自己连接:

where b.courseNo=123 and b.courseNo=125;

 内连接:

只是检索表和表之间符合连接条件的记录

  外连接

定义:在实际应用中,往往需要将不满足连接条件的元组也检索出来,只是在相应的位置用空值代替;

左外连接:

检索左表的全部记录及右表符合连接条件的记录

左外连接的连接结果中包含左关系中的所有元组,对于左关系中没有连接上的元组,其右关系中的相应属性用空值代替

右外连接:

检索右表的全部记录及左表符合连接条件的记录(左外连接的逆向)

右外连接的连接结果中包含关系中的所有元组,对于关系中没有连接上的元组,其左关系中的相应属性用空值代替

全外连接:

全外连接的连接结果中包含左关系中的所有元组,对于左关系中没有连接上的元组,其右关系中的相应属性用空值代替,对于关系中没有连接上的元组,其左关系中的相应属性用空值代

嵌套子查询

  使用in的子查询

  使用比较运算符的子查询

  使用存在量词EXISTS的子查询

  复杂子查询实例

集合运算

SQL查询一般格式

数据库先系统与原理第三章笔记:数据库SQL查询语言的更多相关文章

  1. 第三章基本的SQl查询语言

    ---恢复内容开始--- ---恢复内容结束---

  2. 《APUE》第三章笔记(3)

    文件共享 UNIX系统支持在不同进程中共享打开的文件,首先先用一幅apue的图来介绍一下内核用于I/O文件的数据结构: 如图所见,一个进程都会有一个记录项,记录项中包含有一张打开文件描述符表,每个描述 ...

  3. 《APUE》第三章笔记(2)

    read函数 调用read函数从打开的文件中读数据. #include <unistd.h> ssize_t read(int filedes, void *buf, size_t nby ...

  4. 《APUE》第三章笔记(1)

    以下内容是我看<APUE>第二版第三章的笔记,有错还希望指出来,谢谢. unbuffered I/O,跟buffered I/O相对,buffered I/O就是 ISO C标准下的标准输 ...

  5. HBase in Action前三章笔记

    近期接触HBase,看了HBase In Action的英文版.開始认为还行,做了些笔记.可是兴许看下去,越来越感觉到实战这本书比較偏使用上的细节,对于HBase的具体设计涉及得很少.把前三章的一些笔 ...

  6. 【转】《APUE》第三章笔记(4)及习题3-2

    原文网址:http://www.cnblogs.com/fusae-blog/p/4256794.html APUE第三章的最后面给出的函数,现在还用不着,所以,先留个名字,待到时候用着了再补上好了. ...

  7. 《APUE》第三章笔记(4)及习题3-2

    APUE第三章的最后面给出的函数,现在还用不着,所以,先留个名字,待到时候用着了再补上好了. dup和dup2函数:用来复制文件描述符的 sync函数,fsync函数和fdatasync函数:大致的功 ...

  8. 《HALCON数字图像处理》第三章笔记

    目录 第三章 HALCON图像处理基础 HALCON控制语句 HALCON算子 HALCON图像处理入门 HALCON图像读取 HALCON图像显示 图形窗口 图像显示 显示文字 HALCON图像转换 ...

  9. MongDB篇,第三章:数据库知识3

    MongDB    数据库知识3 修改器 $inc 对某个域的值进行加减修改 $mul 对某个域的值进行乘法修改 $min 如果筛选的文档指定的值小于min则不修改,如果大于min 给定的值则修改为m ...

随机推荐

  1. samba文件共享及账户映射

    samba文件共享及账户映射 实验介绍:在虚拟机Linux系统上安装sanmba服务,并在另外一台虚拟机的win7系统上访问共享文件夹,主要分为:匿名访问.身份验证访问.以及添加白名单和为了保护服务器 ...

  2. 清华大学慕课 (mooc) 数据结构-邓俊辉-讲义-合并版

    邓公的数据结构一直好评如潮,可惜我如今才开始学习它.QAQ 昨天,<数据结构 (2020 春)>的讲义已经推到清华大学云盘上了.苦于 10 拼页的打印版不易在 PC 上阅读(手机上更是如此 ...

  3. GO学习之 安装Go语言及搭建Go语言开发环境

    一.下载 1.下载地址 Go官网下载地址:https://golang.org/dl/ Go官方镜像站(推荐):https://golang.google.cn/dl/ 2.版本的选择 Windows ...

  4. pyqt5 通过QLinearGradient 绘制取色板

    要绘制HSV取色板,一般通过绘制前景色和背景色的方式实现,先绘制前景,然后绘制背景,前景是HSV颜色空间,从左到右,背景是亮度,从上到下,xs和ys是鼠标的当前的位置. def graphicsVie ...

  5. 【转载】巴塞尔问题(Basel Problem)的多种解法

    如何计算 \(\displaystyle \zeta \left ( 2 \right )=\frac{1}{1^{2}}+\frac{1}{2^{2}}+\frac{1}{3^{2}}+\cdots ...

  6. STM32F030 启用内部晶振并配置系统时钟为48M

    在文件 system_stm32f0xx.c 里的函数 static void SetSysClock(void) { if (HSEStatus == (uint32_t)0x01) // 存在外部 ...

  7. C++之void是什么?

    void关键字的使用规则: 1. 如果函数没有返回值,那么应声明为void类型: 2. 如果函数无参数,那么应声明其参数为void: 3. 如果函数的参数可以是任意类型指针,那么应声明其参数为void ...

  8. 关于anaconda-navigator打不开的问题

    19-10版本的anaconda-navigator打不开,没有图形化界面就是很糟糕 在命令行执行各种命令都没有问题,说明anaconda并没有出现大的问题,可能只是图形化界面出了问题. 执行 ana ...

  9. 黑帽JS跳转

    一.常规的JS页面跳转代码 .在原来的窗体中直接跳转用 <script type=”text/javascript”> window.location.href=”http://www.g ...

  10. Python 中多进程、多线程、协程

    进程: 一个运行的程序(代码)就是一个进程,没有运行的代码叫程序,进程是系统资源分配的最小单位,进程拥有自己独立的内存空间,所以进程间数据不共享.开销大. 线程: 调度执行的最小单位,也叫执行路径,不 ...