PLSQL_基础系列7_插入方式Pivoting / Unconditional / Conditional ALL / Conditional FIRST INSERT

2014-12-08 BaoXinjian

一、摘要


Oracle Insert的多种方式

1. standard insert

1. pivoting Insert

2. unconditional insert

3. conditional all insert / conditional first insert

二、标准Insert - 单表单行插入



标准Insert -- 单表单行插入

1. 语法:

INSERT INTO table [(column1,column2,...)] VALUE (value1,value2,...)

2. 示例:

INSERT INTO dep (dep_id,dep_name) VALUES(1,‘技术部‘);

3. 备注:

用标准语法只能插入一条数据,且只能在一张表中插入数据

三、无条件 Insert All - 多表多行插入



无条件 Insert all -- 多表多行插入

1. 语法:

INSERT [ALL] [condition_insert_clause]

[insert_into_clause values_clause] (subquery)

2. 示例:

INSERT ALL
  INTO sal_history(emp_id,hire_date,salary) values (empid,hiredate,sal)
  INTO mgr_history(emp_id,manager_id,salary) values (empid,hiredate,sal)
SELECT employee_id empid,hire_date hiredate,salary sal,manager_id mgr
  FROM employees
 WHERE employee_id>200;

四、有条件的Insert



有条件的Insert

1. 语法:

INSERT [ALL | FIRST]

WHEN condition THEN insert_into_clause values_clause

[WHEN condition THEN] [insert_into_clause values_clause]

......

[ELSE] [insert_into_clause values_clause]

Subquery;

2. 示例:

INSERT All
WHEN id>5 THEN INTO z_test1(id, name) VALUES(id,name)
WHEN id<>2 THEN INTO z_test2(id) VALUES(id)
ELSE INTO z_test3 VALUES (name)
SELECT id,name FROM z_test;

当使用ALL关键字时,oracle会从上至下判断每一个条件,当条件满足时就执行后面的into语句

在上面的例子中,如果ID=6 那么将会在z_test1中插入一条记录,同时也在z_test2中插入一条记录

3. 备注:

当使用FIRST关键字时,oracle会从上至下判断每一个条件,当遇到第一个满足时就执行后面的into语句,

同时中断判断的条件判断,在上面的例子中,如果ID=6,仅仅会在z_test1中插入一条数据

五、旋转Pivoting Insert



旋转Insert (pivoting insert)

create table sales_source_data (
employee_id number(6),
week_id number(2),
sales_mon number(8,2),
sales_tue number(8,2),
sales_wed number(8,2),
sales_thur number(8,2),
sales_fri number(8,2)
);

insert into sales_source_data values (176,6,2000,3000,4000,5000,6000);
create table sales_info (
employee_id number(6),
week number(2),
sales number(8,2)
);

看上面的表结构,现在将要sales_source_data表中的数据转换到sales_info表中,这种情况就需要使用旋转Insert

2. 示例如下:

insert all
into sales_info values(employee_id,week_id,sales_mon)
into sales_info values(employee_id,week_id,sales_tue)
into sales_info values(employee_id,week_id,sales_wed)
into sales_info values(employee_id,week_id,sales_thur)
into sales_info values(employee_id,week_id,sales_fri)
select employee_id,week_id,sales_mon,sales_tue,
sales_wed,sales_thur,sales_fri
from sales_source_data;

3. 从该例子可以看出,所谓旋转Insert是无条件 insert all 的一种特殊应用,但这种应用被oracle官方,赋予了一个pivoting insert的名称,即旋转insert

Thanks and Regards

参考: http://blog.itpub.net/25724608/viewspace-695818

时间: 2024-10-09 19:25:36

PLSQL_基础系列7_插入方式Pivoting / Unconditional / Conditional ALL / Conditional FIRST INSERT的相关文章

PLSQL_基础系列2_分组函数GROUP BY / ROLLUP / CUBE

2014-11-30 BaoXinjian 一.摘要 ROLLUP 运算符生成的结果集类似于 CUBE 运算符生成的结果集. 1. 下面是 CUBE 和 ROLLUP 之间的具体区别: CUBE 生成的结果集显示了所选列中值的所有组合的聚合. ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合. 2. ROLLUP 优点: (1). ROLLUP 返回单个结果集,而 COMPUTE BY 返回多个结果集,而多个结果集会增加应用程序代码的复杂性. (2). ROLLUP 可以在服务器游

PLSQL_基础系列3_合并操作UNION / UNION ALL / MINUS / INTERSET

2014-11-30 BaoXinjian 一.摘要 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到Union或者Union All关键字.Union(或称为联合)的作用是将多个结果合并在一起显示出来. Union和Union All的区别是,Union会自动压缩多个结果集合中的重复结果,而Union All则将所有的结果全部显示出来,不管是不是重复. Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序: Union All:对两个结果集进行

PLSQL_基础系列5_视图控制WITH CHECK OPTION

2014-12-09 BaoXinjian 一.摘要 通过有with check option选项的视图操作基表(只是面对单表,对连接多表的视图正在寻找答案),有以下结论: 首先视图只操作它可以查询出来的数据,对于它查询不出的数据,即使基表有,也不可以通过视图来操作. 1. 对于update, 有with check option,要保证update后,数据要被视图查询出来 2. 对于delete, 有无with check option都一样 3. 对于insert, 有with check

PLSQL_基础系列4_时间间隔INTERVAL

2014-12-08 BaoXinjian 一.摘要 INTERVAL数据类型用来存储两个时间戳之间的时间间隔. 可以指定years and months,或者days,hours,minuts,seconds之间的间隔. ORACLE支持两种INTEVAL类型,它们分别是YEAR TO MONTH和DAY TO SECOND. 每个类型都包含leading field和trailing field.主参数定义要被计算的date或者time,副参数定义最小增长量 二.语法 1. Oracle语法

PLSQL_基础系列1_正则表达式regexp_like/substr/instr/replace

2014-11-30 BaoXinjian 一.摘要 ORACLE中的支持正则表达式的函数主要有下面四个: 1 REGEXP_LIKE :与LIKE的功能相似 2 REGEXP_INSTR :与INSTR的功能相似 3 REGEXP_SUBSTR :与SUBSTR的功能相似 4 REGEXP_REPLACE :与REPLACE的功能相似 它们在用法上与Oracle SQL 函数LIKE.INSTR.SUBSTR 和REPLACE 用法相同. 二.调用格式 1. 格式: REGEXP_INSTR

PLSQL_基础系列9_时间戳Timestamp

2013-11-09 BaoXinjian 1. 获取系统时间的语句(ssxff6获取小数点后面六位) select sysdate,systimestamp,to_char(systimestamp, 'yyyymmdd hh24:mi:ssxff6'), to_char(systimestamp, 'yyyymmdd hh24:mi:ss.ff6') from dual; 2. 字符型转成timestamp select to_timestamp('2011-09-14 12:52:42.1

PLSQL_基础系列1_正则表达REGEXP_LIKE / SUBSTR / INSTR / REPLACE

2014-11-30 BaoXinjian 一.摘要 ORACLE中的支持正则表达式的函数主要有下面四个: 1 REGEXP_LIKE :与LIKE的功能相似 2 REGEXP_INSTR :与INSTR的功能相似 3 REGEXP_SUBSTR :与SUBSTR的功能相似 4 REGEXP_REPLACE :与REPLACE的功能相似 它们在用法上与Oracle SQL 函数LIKE.INSTR.SUBSTR 和REPLACE 用法相同. 二.调用格式 1. 格式: REGEXP_INSTR

PLSQL_基础系列8_操作符标LPAD / TRUNC / DECODE / TRIM / INSTR

2014-12-09 BaoXinjian 一.字符函数 1. LOWER (strexp) - 返回字符串,并将所有的字符小写. select lower('ABCDE') from dual 2. UPPER (strexp)     返回字符串,并将所有的字符大写. select upper('abcdf') from dual 3.INITCAP(strexp)    将字符串的(每个单词的)第一个字母变为大写,后面的小写; select initcap(' source fore')

PLSQL_基础系列6_判断操作NVL / NULLIF / COALESCE / NVL2

2014-12-08 BaoXinjian 一.摘要 下列函数可用于任何数据类型,且适合使用空值的场合:NVL (expr1, expr2)NVL2 (expr1, expr2, expr3)NULLIF (expr1, expr2)COALESCE (expr1, expr2, ..., exprn) 二.案例 - NVL 1. NVL函数的格式如下:NVL(expr1,expr2) 2. 含义是:如果oracle第一个参数为空那么显示第二个参数的值,如果第一个参数的值不为空,则显示第一个参数