DML(数据操纵语言)#

INSERT 、UPDATE、 DELETE

插入操作:INSERT:

语法: INSERT INTO 表名(列名1,列名2 ...)VALUES(列值1,列值2...);

注意:列名与列值的类型、个数、顺序要一一对应。

   可以把列名当做java中的形参,把列值当做实参。

   值不要超出列定义的长度。

   如果插入空值,请使用null

   插入的日期和字符一样,都使用引号括起来。

修改操作 UPDATE:

  语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 ........ WHERE 列名=值

删除操作 DELETE:

语法 : DELETE FROM 表名 【WHERE 列名=值】

注意:where语句可以不写

   DELETE :删除表中的数据,表结构还在;删除后的数据可以找回。

   TRUNCATE :删除是把表直接DROP掉,然后再创建一个同样的新表。

   删除的数据不能找回。执行速度比DELETE快。

DQL(数据查询语言)

 **查询表中的所有数据 **

 语法: SELECT 列名 FROM表名

    [WHERE --> GROUP BY -->HAVING--> ORDER BY]

语法:

  SELECT selection_list /*要查询的列名称*/
FROM table_list /*要查询的表名称*/
WHERE condition /*行条件*/
GROUP BY grouping_columns /*对结果分组*/
HAVING condition /*分组后的行条件*/
ORDER BY sorting_columns /*对结果分组*/
LIMIT offset_start, row_count /*结果限定*/

  DML是对表中的数据进行增、删、改的操作。不要与DDL(数据定义语言)混淆了。

  查询代码的书写顺序和执行顺序

 查询语句书写顺序:select – from- where- group by- having- order by-limit

 查询语句执行顺序:from -> where  --> group by  --> having --> select --> order by --> limit

注:其中WHERE 语句执行顺序是从右到左

组函数(多行函数,分组函数)

  注:组函数会自动忽略空值,NVL函数使分组函数无法忽略空值

  • AVG(expr) 求平均值

  • COUNT([DISTINCT] expr) 统计行数,当expr=*时,所有的行数,expr=COLUMN时会自动过滤对应列的空值的行数

    DISTINCT 去掉重复行

  • MAX(expr) 求最大值

  • MIN(expr) 求最小

  • SUM(expr) 求和

分组函数(GROUP BY)

  注:SELECT 中的列不在组函数中就必须在 GROUP BY 中

    多个列的分组:先按照第一个列分组,如果相同,再第二个列分组,依次类推

SELECT
deptno,
job,
AVG( sal )
FROM
emp
GROUP BY
deptno,
job;

Oracle的增强GROUP BY:用于做财务报表

**break on deptno skip 2 **

-- 部门号只显示一个,不同的部门号跳过2行

break on null 关闭设置

GROUP BY ROLLUP(a,b) 增强分组

例子

SELECT
deptno,
job,
SUM( sal )
FROM
emp
GROUP BY
ROLLUP (
deptno,
job)

上面代码相当于下面几个分组函数的和

SELECT
deptno,
job,
SUM( sal )
FROM
emp
GROUP BY
deptno,
job;
+
SELECT
deptno,
SUM( sal )
FROM
emp
GROUP BY
deptno,
job;
+
SELECT
SUM( sal )
FROM
emp
GROUP BY
deptno,
job

即:

GROUP BY a,b  +  GROUP BY a + 没有GROUP BY

过滤分组(HAVING)

  注:不能再WHERE子句中使用组函数

    可以在HAVING 子句中使用组函数,尽量使用WHERE

SELECT
deptno,
job,
AVG( sal )
FROM
emp
GROUP BY
deptno,
job
HAVING AVG(sal)>300;

重点:HAVING 可以和组函数配合使用,不是必须和GROUP BY配合,例子如下

	SELECT COUNT(*)
from dual
HAVING COUNT(*)>0;

多表查询

  • 连接类型
  • 等值连接
  • 不等值连接
  • 外连接
  • 自连接

左外连接:当条件不成立的时候,等号左边的表依然包含在最后的结果中

写法:

WHERE e.deptno=d.deptno(+) 或者FROM emp e right outer join dept d on e.deptno=d.deptno

右外连接:当条件不成立的时候,等号右边的表依然包含在最后的结果中

写法:

WHERE e.deptno(+)=d.deptno 或者FROM emp e left outer join dept d on e.deptno=d.deptno

例子

按部门号查询部门号,部门名称,人数

SELECT d.deptno 部门号,d.dname 名称,COUNT(e.empno) 人数
FROM emp e ,dept d
WHERE e.deptno(+)=d.deptno
GROUP BY d.deptno,d.dname SELECT d.deptno 部门号,d.dname 名称,COUNT(e.empno) 人数
FROM emp e right outer join dept d
on e.deptno=d.deptno
GROUP BY d.deptno,d.dname

自连接: 通过表的别名,将同一张表视为多张表

注:自连接不适合操作大表

-- 查询员工信息: 员工姓名 老板名

SELECT e1.empno,e1.ename 员工,e2.empno,e2.ename 老板
FROM emp e1 left outer join emp e2
on e1.mgr=e2.empno SELECT e1.empno,e1.ename 员工,e2.empno,e2.ename 老板
FROM emp e1 , emp e2
WHERE e1.mgr=e2.empno(+)

层次查询

实质是单表查询

  在层次查询中Oracle为我们提供了伪列 leval

  

上面的自连接问题:

  查询员工信息: 员工姓名 老板名

SELECT LEVEL ,empno, ename,mgr
FROM emp
CONNECT BY PRIOR empno=mgr
START WITH mgr IS NULL;

Oracle常用sql语句(二)之组函数、多表查询的更多相关文章

  1. oracle常用SQL语句(汇总版)

    Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, ...

  2. oracle 常用sql语句

    oracle 常用sql语句 1.查看表空间的名称及大小 select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_sizefrom d ...

  3. 剑指Offer——常用SQL语句、存储过程和函数

    剑指Offer--常用SQL语句.存储过程和函数 常用SQL语句 1.在MySQL数据库建立多对多的数据表关系 2.授权.取消授权 grant.revoke grant select, insert, ...

  4. Oracle常用SQL语句大全

    常用Oracle数据库SQL语句汇总. 1.常用操作 --清空回收站purge recyclebin;--查询回收站select * from recyclebin--查询Oracle版本信息sele ...

  5. ysql常用sql语句(12)- group by 分组查询

    测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1683347.html 前言 ...

  6. Mysql常用sql语句(11)- between and 范围查询

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 between and可以判断值是否在指定范围内 ...

  7. Mysql常用sql语句(19)- in / exists 子查询

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 子查询在我们查询方法中是比较常用的,通过子查询可 ...

  8. Mysql常用sql语句(7)- order by 对查询结果进行排序

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 通过select出来的结果集是按表中的顺序来排序 ...

  9. Mysql常用sql语句(10)- is null 空值查询

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 is null是一个关键字来的,用于判断字段的值 ...

随机推荐

  1. 转:机器学习 规则化和模型选择(Regularization and model selection)

    规则化和模型选择(Regularization and model selection) 转:http://www.cnblogs.com/jerrylead/archive/2011/03/27/1 ...

  2. C++四种类型转化

    2018-08-02 (星期四)C++类型转换:static_cast提供编译时期静态类型检测:    static_cast <type-id> (expression)    1)完成 ...

  3. 【BZOJ4755】扭动的回文串(Manacher,哈希)

    [BZOJ4755]扭动的回文串(Manacher,哈希) 题面 BZOJ 题解 不要真的以为看见了回文串就是\(PAM,Manacher\)一类就可以过. 这题显然不行啊. 我们主要考虑如何解决跨串 ...

  4. HiHoCoder1513:小Hi的烦恼——题解

    https://hihocoder.com/problemset/problem/1513 小Hi从小的一大兴趣爱好就是学习,但是他发现尽管他认真学习,依旧有学神考的比他好. 小Hi在高中期间参加了市 ...

  5. Classical Binary Search

    Find any position of a target number in a sorted array. Return -1 if target does not exist. 与题目 Firs ...

  6. GitLab安装部署与管理

    一.安装Gitlab前系统预配置准备工作 操作系统:centos 7.3 1.关闭firewalld防火墙 #systemctl stop firewalld //关闭防火墙 #systemctl d ...

  7. POJ 2007 Scrambled Polygon 极角序 水

    LINK 题意:给出一个简单多边形,按极角序输出其坐标. 思路:水题.对任意两点求叉积正负判断相对位置,为0则按长度排序 /** @Date : 2017-07-13 16:46:17 * @File ...

  8. sql server常用函数、常用语句

    一.常用函数 1.字符串函数 : charindex(':','abc:123')    --寻找一个字符在一段字符串中起始的位置 len('zhangsan')   --获取一段字符串的长度 lef ...

  9. CSS 定位相关属性 :position

    我们平时经常用margin来进行布局,但是遇到一些盒子不规律布局时,用margin就有点麻烦了,这个时候我们可以用position. position:参数 参数分析: 一.absolute: 相对父 ...

  10. NSPredicate--谓词(is)

    技术博客http://www.cnblogs.com/ChenYilong/ 新浪微博http://weibo.com/luohanchenyilong NSPredicate 技术博客http:// ...