从中文语法上来说,应该先写FROM语句比较好理解

基础查询语句

SELECT [DISTINCT] target-list
FROM tables
WHERE qualification
GROUP BY grouping-list
HAVING group-qualification
  • DISTINCT:要求结果没有重复元组

查询过程(不优化,好理解)

  1. 将tables做笛卡尔乘积(FROM)
  2. 根据qualification删除元组(WHERE)
  3. 根据target-list删除的属性(SELECT)
  4. 根据是否DISTINCT删除重复元组
  5. 根据group-list分组(GROUP BY)
  6. 根据group-qu alification删除组(HAVING)

注意:select语句和having语句里的属性只能是group by里属性的子集。例如:group by sex,那么select和having里不能有sname。

定义列别名

SELECT SNAME AS '学生姓名'

范围条件BETWEEN AND

SELECT SNAME FROM S WHERE BIRTHDADY NOT BETWEEN '1996-07-01' AND '1998-06-30'

属于集合条件 IN

SELECT SNAME FROM S WHERE SID IN (SELECT SID FROM S WHERE xxx)

字符匹配

SELECT * FROM S WHERE SNO LIKE 'S_%0'

'-'为通配符,匹配任意一个字符

'%'匹配任意个字符

聚合函数

COUNT(*)
COUNT([DISTINCT] A)
SUM([DISTINCT] A)
AVG([DISTINCT] A)
MAX(A)
MIN(A)

一般group by要和聚合函数一起使用。

CAST表达式

CAST (Expression AS Data type)

例子:

Students (name, school)
Soldiers (name, service) CREATE VIEW PROSPECTS(name, school, service) AS
SELECT name, school, CAST(NULL AS Varchar(20))
UNION
SELECT name, CAST(NULL AS Varchar(20)), service
FROM Soldiers;

有点类似C++里的强制类型转换。

CASE表达式

例子:

Officers (name, status, rank, title)
SELECT name, CASE status
WHEN 1 THEN 'Active Duty'
WHEN 2 THEN 'Reserve'
WHEN 3 THEN 'Special Assignment'
WHEN 4 THEN 'Retired'
ELSE 'Unknown'
END AS tatus
FROM Officers;

给status重命名以便于阅读。

例子:

Machines (id, type, ohurs_used, accidents)
'找到“chain saw”故障时间所占比例'
SELECT sum(CASE
WHEN type='chain saw' THEN accidents
ELSE 0e0
END) / sum(accidents)
FROM Machines;

子查询(嵌套查询)

  • 结果是一个值

    '工作在纽约的部门和这个部门最高工资'
    SELECT d.deptno, d.deptname, (SELECT MAX(salary)
    FROM emp
    WHERE deptno = d.deptno) AS maxpay
    FROM dept AS d
    WHERE d.location = 'New York';
  • 结果是表

    '查询每年新入职员工的平均pay'
    SELECT startyear, avg(pay)
    FROM (SELECT name salary+bonus AS pay,
    year(startdate) AS startyear
    FROM emp) AS emp2
    GROUP BY startyear;
  • 公共表表达式(临时视图)

    防止payroll运算两次。

    '查找总收入最高的部门'
    WITH payroll (depno, totalpay) AS
    (SELECT deptno, sum(salary) + sum(bonus)
    FROM emp
    GROUP BY deptno)
    SELECT deptno
    FROM payroll
    WHERE totalpay = (SELECT max(totalpay)
    FROM payroll)

    实现外连接

    WITH
    '自然连接'
    innerjoin(name, rank, subject, enrollment) AS
    (SELECT t,name, t.rank, c.subject, c.rnrollment
    FROM teachers AS t, course AS c
    WHERE t.name=c.teacher AND c.quarter='FALL 96'),
    '左外连接'
    teacher-only(name, rank) AS
    (SELECT name, rank
    FROM teachers
    EXCEPT ALL
    SELECT name, rank
    FROM innerjoin),
    '右外连接'
    course-only(subject, enrollment) AS
    (SELECT subject, enrollment
    FROM courses
    EXCEPT ALL
    SELECT subject, enrollment
    FROM innerjoin) SELECT name, rank, subject, enrollment
    FROM innerjoin
    UNION ALL
    SELECT name, rank,
    CAST (NULL AS Varchar(20)) AS subject
    CAST (NULL AS Integer) AS enrollment
    FROM teacher-only
    UNION ALL
    SELECT CAST (NULL AS Varchar(20)) AS name,
    CAST (NULL AS Varchar(20)) AS rank,
    subject, enrollment
    FROM course-only;

SQL之QL的更多相关文章

  1. Spark SQL慕课网日志分析(1)--系列软件(单机)安装配置使用

    来源: 慕课网 Spark SQL慕课网日志分析_大数据实战 目标: spark系列软件的伪分布式的安装.配置.编译 spark的使用 系统: mac 10.13.3 /ubuntu 16.06,两个 ...

  2. 《开源大数据分析引擎Impala实战》目录

    当当网图书信息: http://product.dangdang.com/23648533.html <开源大数据分析引擎Impala实战>目录 第1章  Impala概述.安装与配置.. ...

  3. Oracle 单行函数

    一.什么是函数 任何东西,只要它能接收输入,对输入进行加工并产生输出,它就可以被称为函数. 二.单行函数简介 单行函数只对表中的一行数据进行操作,并且对每一行数据只产生一个输出结果.单行函数可以接受一 ...

  4. 《Java程序设计》终极不改版

     半年前的作品,上传只为纪念~ 成绩: ____0.1______ Java程序设计  课程设计 题 目:大学生信息管理系统 学 院:  计算机与软件学院 专 业:     网络工程_____­ .  ...

  5. Spark源码系列:DataFrame repartition、coalesce 对比

    在Spark开发中,有时为了更好的效率,特别是涉及到关联操作的时候,对数据进行重新分区操作可以提高程序运行效率(很多时候效率的提升远远高于重新分区的消耗,所以进行重新分区还是很有价值的).在Spark ...

  6. 20145229吴姗珊《网络对抗》WEB基础实践

    20145229吴姗珊<网络对抗>WEB基础实践 基础与实践 基础问题 1.什么是表单 表单是可以收集用户的信息和反馈意见,是网站管理者与浏览者之间沟通的桥梁. 一部分是HTML源代码用于 ...

  7. Hive入门指南

    转自:http://blog.csdn.net/zhoudaxia/article/details/8842576 1.安装与配置 Hive是建立在Hadoop上的数据仓库软件,用于查询和管理存放在分 ...

  8. 日志管理-rsyslog日志服务器及loganalyzer

    一,日志基础 日志:记录时间,地点,任务,事件 格式:日期时间 主机 进程[pid]: 事件内容 rsyslog 特性: 多线程,UDP, TCP, SSL, TLS, RELP,MySQL, PGS ...

  9. 1.windows-oracle实战第一课

    一.oracle是目前最流行的数据库之一,功能强大.性能卓越.学习要有信心.oracle也做软件,不仅仅是数据库.比如ERP(企业资源计划,用友.金蝶) 二.目前的数据库   相对而言:       ...

  10. python编程训练

    1. 反转字符串: 1 #encoding=utf-8 2 #import string 3 from collections import deque 4 5 def reverse1(string ...

随机推荐

  1. PHP中文件锁

    PHP中文件锁 文件锁的用途: 若一个人在写入一个文件,另外一个人同时也打个了这个文件进行写入文件. 这情况下,如果遇到一定的碰撞概率的话,不知道到底谁的操作为准. 因此,这个时候我们引入锁机制. 若 ...

  2. 音频处理实用AI工具

    最近在做音频处理相关的工作,主要有以下几个好用的工具. 1. 语音转文字--whisper 这是一款由OpenAI开发的语音转文字工具,项目地址位于:openai/whisper. 这个工具是用来生成 ...

  3. 麒麟V10虚拟机安装(详细)

    现在国企和央企单位都在做国产化适配工作,服务器采用:中科曙光(海光Hygon).中科德泰(龙芯Loongson).宝德(鲲鹏Kunpeng)等国产配备国产处理器的服务器:数据库采用:人大金仓(King ...

  4. Linux-find命令报错: missing argument to `-exec'

    报错提示:find: missing argument to `-exec' 今天写一个清理脚本,用到了find命令.本来是这么写的: find . -type f -mtime +7 -name & ...

  5. [数据结构] 串与KMP算法详解

    写在前面 今天是农历大年初三,祝大家新年快乐! 尽管新旧交替只是一个瞬间,在大家互祝新年快乐的瞬间,在时钟倒计时数到零的瞬间,在烟花在黑色幕布绽放的瞬间,在心底默默许下愿望的瞬间--跨入新的一年,并不 ...

  6. wsl 配置ubuntu apt源为阿里源

    $ sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak $ sudo sed -i 's/security.ubuntu/mirrors.a ...

  7. virtualapp 应用启动源码分析

    应用启动源码分析 在HomeActvity中的OnCreate方法会调用initLaunchpad private void initLaunchpad() { mLauncherView.setHa ...

  8. ASP.NET Core 微信支付(四)【支付结果通知回调(未按照官方步骤) APIV3】

    官方文档 支付通知API 证书和回调报文解密 参考资料 netcore 中没有Request.InputStream 理论实战 对于我来说,这个微信支付结果通知回调有两个难点. 难点一 一开始在想是怎 ...

  9. vue upload 图片转base64、转二进制数组,保存编码数据到文件

    功能需求 1.图片转base64 2.base 64 转二进制数组 3.保存二进制数据到文件下载到本地 解决方法 问题1: 参考资料 vue element upload图片 转换成base64 具体 ...

  10. 【LeetCode回溯算法#09】全排列,排列问题以及其中涉及的去重操作

    全排列 力扣题目链接 给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 .你可以 按任意顺序 返回答案. 示例 1: 输入:nums = [1,2,3] 输出:[[1,2,3],[1, ...