一、插入 insert 操作:

1. 复制表结构但不新增数据:

  1. -- 复制表结构但不插入数据
  2. create table emp_new as select * from emp where 1 = 2;
  3. select * from emp_new;

2. 利用 with check option,配合视图,能够为插入数据操作做一些限制:

  1. -- with check optiom 限制数据的插入
  2. insert into (select empno, deptno, empname, empsalary, empdesc
  3. from emp
  4. where emp.deptno <> 'dept02'-- with check option
  5. )
  6. values('emp008', 'dept02', 'Ross', 7000, '对行业发展趋势有较强的洞察力。有统筹全局能力');

运行报错:ORA-01402:视图 WITH CHECK OPTIDN违反 where子句

3. 多表插入:

这里讲三种多表插入:a. 无条件 insert;b. 有条件 insert;c. insert first。

  • 无条件 insert all

先将 emp 和 emp_bak 清空,再运行下边 sql:

  1. -- 无条件 insert all
  2. insert all
  3. into emp_new1
  4. into emp_new2
  5. select * from emp;

此语是将 emp 的数据同一时候插入到 emp_new1、emp_new2 表里,运行 select * from emp_new1 的结果例如以下(emp_new2 的数据集也是如此):

  • 有条件 insert all
  1. -- 有条件 insert all
  2. insert all
  3. when empsalary < 5000
  4. then into emp_new1
  5. when empsalary > 3000
  6. then into emp_new2
  7. select * from emp;

运行上边 sql 后,工资(empsalary)小于 5000 的员工信息插入 emp_new1。工资(empsalary)大于 3000 的员工信息插入 dept_new2。当中 empsalary 为 4000 的同一时候插入了 emp_new1 和 emp_new2,有时候须要插入指定的表。这个在下边讲

  • insert first

insert first  假设前边有条件符合。后边的表就不会插入相应的行:

  1. -- insert first
  2. insert first
  3. when empsalary < 5000
  4. then into emp_new1
  5. when empsalary > 3000
  6. then into emp_new2
  7. when empsalary > 3000
  8. then into emp_new3
  9. select * from emp;

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

emp_new2 不会插入 empsalary 为 4000 的这条记录,emp_new3 没有记录插入。

二、更新 update 操作:

1. 利用 select 子查询进行 update。须要注意避免全表更新:

数据准备,先将 emp_new1 中全部记录的 empdesc 置为 “未填写”

如今准备依据 emp_new1 表中的记录去更新 emp 表中 empno 相应记录的 empdesc,好多人会写成例如以下 sql:

  1. -- 利用 select 进行 update 进行了全表更新
  2. update emp
  3. set emp.empdesc =
  4. (select empdesc
  5. from emp_new1
  6. where emp.empno = emp_new1.empno
  7. );

上边的结果说明,这个 update 操作的 sql 进行了全表扫描。

对 empno 没有匹配到的记录,均被更新为 null

其实应该加上 where 语句才是正确的:

  1. update emp
  2. set emp.empdesc =
  3. (select empdesc
  4. from emp_new1
  5. where emp.empno = emp_new1.empno
  6. )
  7. where exists (select 1
  8. from emp_new1
  9. where emp.empno = emp_new1.empno
  10. )

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

2. merge into 语句:

针对上边的语句,能够用 merge into 语句

  1. -- merge into 的实现方法
  2. merge into emp
  3. using (select *
  4. from emp_new1
  5. ) e
  6. on (e.empno = emp.empno)
  7. when matched then
  8. update set emp.empdesc = e.empdesc;

执行结果和 1 中结果一样,假设做推断。推荐使用 merge into 方法。

由于 merge into 仅仅訪问一次 emp_new1。

三、删除 delete 操作

1. 删除反复记录:

方法有非常多种,这里仅仅说一种,利用分析函数分组。推断 分组序号是否大于 1.

  1. delete
  2. from emp
  3. where rowid in (select rid
  4. from (select rowid as rid,
  5. row_number() over(partition by empsalary order by empno asc) as seq
  6. from emp
  7. )
  8. where seq > 1
  9. );

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

可是,假设须要删除全然同样的两条数据中的一条,须要在 partition by 后边加上全部列名,否则删除哪条数据并不确定,删掉记录是和 order by 语句相关的。

Oracle SQL 查询优化.Part4的更多相关文章

  1. Oracle SQL 硬解析和子游标

    Oracle SQL 硬解析和子游标 What reasons will be happening sql hard parse and generating new child cursors 在一 ...

  2. Oracle SQL性能优化技巧大总结

    http://wenku.baidu.com/link?url=liS0_3fAyX2uXF5MAEQxMOj3YIY4UCcQM4gPfPzHfFcHBXuJTE8rANrwu6GXwdzbmvdV ...

  3. Oracle SQL执行缓慢的原因以及解决方案

     以下的文章抓哟是对Oracle SQL执行缓慢的原因的分析,如果Oracle数据库中的某张表的相关数据已是2亿多时,同时此表也创建了相关的4个独立的相关索引.由于业务方面的需要,每天需分两次向此表中 ...

  4. Oracle SQL Developer 连接 MySQL

    1. 在ORACLE官网下载Oracle SQL Developer第三方数据库驱动 下载页面:http://www.oracle.com/technetwork/developer-tools/sq ...

  5. Oracle sql连接

    inner-join                    left-outer-join                 right-outer-join                 full- ...

  6. 解决Oracle SQL Developer无法连接远程服务器的问题

    在使用Oracle SQL Developer连接远程服务器的时候,出现如下的错误 在服务器本地是可以正常连接的.这个让人想起来,跟SQL Server的一些设计有些类似,服务器估计默认只在本地监听, ...

  7. Oracle sql语句执行顺序

    sql语法的分析是从右到左 一.sql语句的执行步骤: 1)词法分析,词法分析阶段是编译过程的第一个阶段.这个阶段的任务是从左到右一个字符一个字符地读入源程序,即对构成源程序的字符流进行扫描然后根据构 ...

  8. Oracle SQL explain/execution Plan

    From http://blog.csdn.net/wujiandao/article/details/6621073 1. Four ways to get execution plan(anyti ...

  9. 处理 Oracle SQL in 超过1000 的解决方案

    处理oracle sql 语句in子句中(where id in (1, 2, ..., 1000, 1001)),如果子句中超过1000项就会报错.这主要是oracle考虑性能问题做的限制.如果要解 ...

随机推荐

  1. win8.1 uefi引导

    装上win8后,感觉似乎开机比win7要慢一些,但实际掐表又发现几乎无差别,但是看网上别人都说 win8可以10秒以内开机,然后又说他们是采用uefi引导,而不是bios引导,那我也试试吧,如下: 1 ...

  2. [LeetCode] Number of 1 Bits 位操作

    Write a function that takes an unsigned integer and returns the number of ’1' bits it has (also know ...

  3. [LeetCode] Binary Tree Postorder Traversal dfs,深度搜索

    Given a binary tree, return the postorder traversal of its nodes' values. For example:Given binary t ...

  4. Python学习杂记_2_格式化字符串的一些操作

    name=input("Please input your name: ") sex=input("Please input your sex: ") prin ...

  5. HDU 6227.Rabbits-规律 (2017ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学))

    Rabbits Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total S ...

  6. Codeforces 912E Prime Gift(预处理 + 双指针 + 二分答案)

    题目链接 Prime Gift 题意  给定一个素数集合,求第k小的数,满足这个数的所有质因子集合为给定的集合的子集. 保证答案不超过$10^{18}$ 考虑二分答案. 根据折半的思想,首先我们把这个 ...

  7. 2017广东工业大学程序设计竞赛决赛 F(LCA + 斐波那契数列性质)

    不能组成三角形的极端数列:1,1,2,3,5,8,13,21,……到第50项时候肯定到1e9了…… 如果两个点之间距离大于50,则直接Yes…… 否则的话直接暴力取出所有边,然后升序排序,判断一下就可 ...

  8. Axure基础操作

    一  简介 Axure RP就是一个快速原型(Rapid Prototyping)设计工具. 快速原型(快速模型demo)在真正的开发之前,构造一个原型.把需求模块进行落实.实现部分交互. 二  Ax ...

  9. Algorithm | hash

    A basic requirement is that the function should provide a uniform distribution of hash values. A non ...

  10. Light oj 1125 - Divisible Group Sums (dp)

    题目链接:http://www.lightoj.com/volume_showproblem.php?problem=1125 题意: 给你n个数,q次询问,每次询问问你取其中m个数是d的整数倍的方案 ...