SQL之QL
从中文语法上来说,应该先写FROM语句比较好理解
基础查询语句
SELECT [DISTINCT] target-list
FROM tables
WHERE qualification
GROUP BY grouping-list
HAVING group-qualification
- DISTINCT:要求结果没有重复元组
查询过程(不优化,好理解)
- 将tables做笛卡尔乘积(FROM)
- 根据qualification删除元组(WHERE)
- 根据target-list删除的属性(SELECT)
- 根据是否DISTINCT删除重复元组
- 根据group-list分组(GROUP BY)
- 根据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的更多相关文章
- Spark SQL慕课网日志分析(1)--系列软件(单机)安装配置使用
来源: 慕课网 Spark SQL慕课网日志分析_大数据实战 目标: spark系列软件的伪分布式的安装.配置.编译 spark的使用 系统: mac 10.13.3 /ubuntu 16.06,两个 ...
- 《开源大数据分析引擎Impala实战》目录
当当网图书信息: http://product.dangdang.com/23648533.html <开源大数据分析引擎Impala实战>目录 第1章 Impala概述.安装与配置.. ...
- Oracle 单行函数
一.什么是函数 任何东西,只要它能接收输入,对输入进行加工并产生输出,它就可以被称为函数. 二.单行函数简介 单行函数只对表中的一行数据进行操作,并且对每一行数据只产生一个输出结果.单行函数可以接受一 ...
- 《Java程序设计》终极不改版
半年前的作品,上传只为纪念~ 成绩: ____0.1______ Java程序设计 课程设计 题 目:大学生信息管理系统 学 院: 计算机与软件学院 专 业: 网络工程_____ . ...
- Spark源码系列:DataFrame repartition、coalesce 对比
在Spark开发中,有时为了更好的效率,特别是涉及到关联操作的时候,对数据进行重新分区操作可以提高程序运行效率(很多时候效率的提升远远高于重新分区的消耗,所以进行重新分区还是很有价值的).在Spark ...
- 20145229吴姗珊《网络对抗》WEB基础实践
20145229吴姗珊<网络对抗>WEB基础实践 基础与实践 基础问题 1.什么是表单 表单是可以收集用户的信息和反馈意见,是网站管理者与浏览者之间沟通的桥梁. 一部分是HTML源代码用于 ...
- Hive入门指南
转自:http://blog.csdn.net/zhoudaxia/article/details/8842576 1.安装与配置 Hive是建立在Hadoop上的数据仓库软件,用于查询和管理存放在分 ...
- 日志管理-rsyslog日志服务器及loganalyzer
一,日志基础 日志:记录时间,地点,任务,事件 格式:日期时间 主机 进程[pid]: 事件内容 rsyslog 特性: 多线程,UDP, TCP, SSL, TLS, RELP,MySQL, PGS ...
- 1.windows-oracle实战第一课
一.oracle是目前最流行的数据库之一,功能强大.性能卓越.学习要有信心.oracle也做软件,不仅仅是数据库.比如ERP(企业资源计划,用友.金蝶) 二.目前的数据库 相对而言: ...
- python编程训练
1. 反转字符串: 1 #encoding=utf-8 2 #import string 3 from collections import deque 4 5 def reverse1(string ...
随机推荐
- Hello,World! 6.28
代码 public class Hello{ public static void main(String[] args){ System.out.print("Hello,World!&q ...
- shell find 根据时间获取文件列表
根据时间得到文件,可以使用find进行查找,支持查找: find以时间为条件查找可用选项: -amin n:查找n分钟以前被访问过的所有文件. -atime n:查找n天以前被访问过的所有文件. -c ...
- NC15976 小C的周末
题目链接 题目 题目描述 愉快的周末到了,小C和他的N-1个朋友买了M个游戏,游戏编号从1~M.每个游戏都是多人游戏,他们打算周末一起打游戏. 小C的每个朋友都决定好了要玩哪一款游戏(会有一组人打同一 ...
- NC20240 [SCOI2005]互不侵犯KING
题目链接 题目 题目描述 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案. 国王能攻击到它上下左右,以及左上 左下右上右下八个方向上附近的各一个格子,共8个格子. 输入描述 只有一行 ...
- Python中文件读写操作
1 txt文件 1.1 写操作 import numpy as np def write(fileName,data): file=open(fileName,'w') row,col=data.sh ...
- 使用Java语言搭建一个简易的局域网直播(live)系统
演示一下 由于是局域网直播系统,那么最简单的情况应该也有两部分构成:录制直播和播放直播. 录制直播 录制直播使用的是本机的摄像头和麦克风,使用Java自带的JFrame窗口播放,支持音视频的录制.效果 ...
- 产品分享:Qt鸿图电子智慧白板(适合会议机、电子黑板、电子笔记、电子阅读器等场景),当前版本v1.0.0
产品 鸿途电子智慧白板. 原理 使用Qt技术为基础,开发的windows/ubuntu/arm电子绘图板,主要为windows,支持触摸鼠标,可以定制跨平台. 适合场景 1.会议机 ...
- zlib开发笔记(一):zlib库介绍、编译和工程模板
前言 Qt使用一些压缩解压功能,介绍过libzip库编译,本篇说明zlib库. zlib库 zlib被设计为一个免费的,通用的,法律上不受限制的-即不受任何专利保护的无损数据压缩库,几乎可 ...
- pika
生产者代码 # -*- coding: utf-8 -*- # pylint: disable=C0111,C0103,R0205 import json import pika from pika. ...
- 在RecyclerView.Adapter中使用 ViewBinding 的一个注意点
使用 viewpager2 时遇到如下错误, 使用 recyclerview 也有可能会遇到 : 2022-02-10 14:15:43.510 12151-12151/com.sharpcj.dem ...