Oracle学习笔记之四,SQL语言入门
1. SQL语言概述
1.1 SQL语言特点
- 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理。
- 统一性,操作任务主要包括:查询数据;插入、修改和删除数据;建立、修改和删除数据对象;控制对数据和数据对象的读写;保证数据库一致性和完整性。
- 易于移植性。
1.2 SQL语言的分类
- 数据查询语言(DQL),主要是SELECT语句、
- 数据操纵语言(DML),主要包括INSERT、UPDATE、DELETE。
- 事务控制语言(TCL),主要包括COMMIT、ROLLBACK、SAVEPOINT。
- 数据定义语言(DDL),用于建立、修改和删除数据库对象,主要包括CREATE、ALTER、DROP。
- 数据控制语言(DCL),用于执行权限授予和权限收回操作,主要包括GRANT、REVOKE。
2. 检索数据
select {[distinct|all]columns|*}
[into table_name]
from {tables|views|other select}
[where conditions]
[group by columns]
[having conditions]
[order by columns]
筛选查询:
- 比较筛选,主要有6种情况:=,!=,>=,<=,<,>
- 特殊关键字筛选,LIKE/IN/BETWEEN/IS NULL等关键字,它们都可以与NOT合用。如:NOT...BETWEEN...AND
- 逻辑筛选,AND、OR、NOT(正常情况,可以用“AND”和“比较运算符”来代替“BETWEEN...AND”关键字)。
分组查询:
排序查询:
多表关联查询:
- 内连接(INNER JOIN),当只合用JOIN关键字时,默认内连接操作。
- 外连接(LEFT JOIN/RIGHT JOIN/FULL JOIN),左外连接查询表示查询结果还包含左表中不满足连接条件的数据行,以此类推。
- 自连接,如:select emp2.ename 上层管理者,em1.ename as 下属员工 from emp em1 left join emp em2 on em1.mgr=em2.empno order by em1.mgr;
- 交叉连接(CROSS JOIN),交叉连接实际上就是不需要任何连接条件的连接,执行结果是一个笛卡尔积,这种查询结果是冗余的,但可以通过WHERE子句来过滤出有用的信息。
3. Orcale常用系统函数
参考:Oracle学习笔记之五(实践:常用函数)
4. 子查询
4.1 单行子查询
单行子查询是指返回一行数据的子查询语句。当在WHERE子句中引用单行子查询时,可以使用单行比较运行符(=、>、<、>=、<=、<>)。
select empno,ename,sal from emp where sal>(select avg(sal) from emp);
4.2 多行子查询
多行子查询是指返回多行数据的子查询语句。当在WHERE子句使用多行子查询时,必须使用多行运算符(IN、ANY、ALL)。
select empno,ename,job from emp where deptno IN (select deptno from dept where dname<>’SALES’);
ANY运算符必须与单行比较运算符结合使用,并且返回行只要匹配子查询的任何一个结果即可。
select deptno,ename,sal from emp where sal > ANY (select sal from emp where deptno=10) and deptno<>10;
ALL运算符必须与单行比较运算结合使用,并且返回行必须匹配所有子查询结果。
select deptno,ename,sal from emp where sal > ALL (select sal from emp where deptno=30);
4.3 并联子查询
内查询的执行需要借助于外查询,而外查询的执行又离不开内查询的执行。
比如:列出员工工资大于此员工所在岗位的平均工资的清单
select empno,ename,sal from emp f where sal>(select avg(sal) from emp where job=f.job) order by job;
5. 操作数据库
5.1 插入数据(INSERT语句)
INSERT INTO table_name [(column_name1[,column_name2]…)]
VALUES(express1[,express2]…)
INSERT INTO table_name [(column_name1[,column_name2]...) selectSubquery
5.2 更新数据(UPDATE语句)
UPDATE table_name
SET {column_name1=express1[,column_name2=express2...]
| (column_name1[,column_name2…])=(selectSubquery)}
[WHERE condition]
在将UPDATE语句与SELECT语句组合使用时,必须保证SELECT语句返回单一的值。
5.3 删除数据(DELETE语句、TRUNCATE语句)
DELETE FROM table_name
[WHERE condition]
TRUNCATETABLE table_name
Oracle学习笔记之四,SQL语言入门的更多相关文章
- Oracle学习笔记之四sp1,Oracle 11g的常用函数
从Oracle学习笔记之四,SQL语言入门中摘出来的,独立成一章节 3.1 字符类函数 ASCII(c)和CHR(i) 分别用于返回一个字符的ASCII码和返回给定ASCII值所对应的字符. C ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- 学习笔记:oracle学习三:SQL语言基础之sql语言简介、用户模式
目录 1.sql语言简介 1.1 sql语言特点 1.2 sql语言分类 1.3 sql语言的编写规则 2.用户模式 2.1 模式与模式对象 2.2 实例模式scott 本系列是作为学习笔记,用于记录 ...
- 学习笔记:oracle学习三:SQL语言基础之检索数据:简单查询、筛选查询
目录 1. 检索数据 1.1 简单查询 1.1.1 检索所有列 1.1.2 检索指定的列 1.1.3 查询日期列 1.1.4 带有表达式的select语句 1.1.5 为列指定别名 1.1.6 显示不 ...
- Oracle学习笔记四 SQL命令(二):SQL操作语言类别
SQL分为下列语言类别 1.数据定义语言(DDL) Create.Alter.Drop 2.数据操纵语言(DML) Insert.Select.Delete.Update 3.事务控制语言(TCL) ...
- 吴裕雄--天生自然ORACLE数据库学习笔记:SQL语言基础
select empno,ename,sal from scott.emp; SELECT empno,ename,sal FROM scott.emp; selECT empno,ename,sal ...
- Oracle学习笔记六 SQL常用函数
函数的分类 Oracle 提供一系列用于执行特定操作的函数 SQL 函数带有一个或多个参数并返回一个值 以下是SQL函数的分类:
- Oracle学习笔记五 SQL命令(三):Group by、排序、连接查询、子查询、分页
GROUP BY和HAVING子句 GROUP BY子句 用于将信息划分为更小的组每一组行返回针对该组的单个结果 --统计每个部门的人数: Select count(*) from emp group ...
- Oracle RAC学习笔记:基本概念及入门
Oracle RAC学习笔记:基本概念及入门 2010年04月19日 10:39 来源:书童的博客 作者:书童 编辑:晓熊 [技术开发 技术文章] oracle 10g real applica ...
随机推荐
- 初探 hexo博客
近期两天迷上了hexo和gitcafe.最终搭建好了自己的个人主页.以后也能够用那个来写博客啦~直接用的gitcafe的二级域名和server,(gitcafe的server在国外.速度也挺快的),h ...
- (LeetCode 203)Remove Linked List Elements
Remove all elements from a linked list of integers that have value val. ExampleGiven: 1 --> 2 --& ...
- ZH奶酪:标准偏差
标准偏差 标准偏差(Std Dev,Standard Deviation) -统计学名词.一种量度数据分布的分散程度之标准,用以衡量数据值偏离算术平均值的程度.标准偏差越小,这些值偏离平均值就越少,反 ...
- 如何:在 DHTML 代码和客户端应用程序代码之间实现双向通信
https://msdn.microsoft.com/zh-cn/library/a0746166 可以使用 WebBrowser 控件向 Windows 窗体客户端应用程序添加现有的动态 HTML ...
- TQ2440 LCD试验失败经验教训
试验环境:TQ2440开发板(配套TQ4.3寸屏) 试验参考书目:<ARM处理器裸机开发实战--机制而非策略>(以下简称<裸机开发实战>) <裸机开发实战>第13章 ...
- 在 Java SE 6 中监视和诊断性能问题
Java™ Platform, Standard Edition 6 (Java SE) 专注于提升性能,提供的增强工具可以管理和监视应用程序以及诊断常见的问题.本文将介绍 Java SE 平台中监视 ...
- VarPtr 得到地址 指针
在Basic语言演变成QBasic,然后到Visual Basic之前,VarPtr函数就已经存在了.开始,这个函数存在于VB运行库1.0版中.通过声明可以调用这个函数: Declare Functi ...
- SQL左连接右连接
假设有A,B两个表. 表A记录如下: aID aNum 1 a20050111 2 a20050112 3 a20050113 4 ...
- 教您使用java爬虫gecco抓取JD全部商品信息
gecco爬虫 如果对gecco还没有了解可以参看一下gecco的github首页.gecco爬虫十分的简单易用,JD全部商品信息的抓取9个类就能搞定. JD网站的分析 要抓取JD网站的全部商品信息, ...
- reset.css 和 flexible.js
重置css默认样式(淘宝): body, h1, h2, h3, h4, h5, h6, hr, p, blockquote, dl, dt, dd, ul, ol, li, pre, form, f ...