- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
操作数据库;数据操纵;插入数据;(1)插入单行记录;例:向emp表中插入一行记录。
例:向dept表中插入一行记录。
;(2)利用子查询插入数据 ;例:统计各个部门的部门号、部门最高工资和最低工资,并将统计的结果写入到表emp_salary(假设该表已经创建)中。
例:向emp表中插入一行记录,其员工名为FAN,员工号为1235,其他信息与员工名为SCOTT的员工信息相同。;如果要将大量数据插入表中,可以利用子查询直接装载的方式进行。由于直接装载数据的操作过程不写入日志文件,因此数据插入操作的速度大大提高。
利用子查询装载数据语法为:
INSERT /*+APPEND*/ INTO
table_name|view_name[(column1[,column2,…])
subquery;
例如,复制emp表中empno,ename,deptno三列的值,并插入到new_emp表中,语句为:;(3)向多个表中插入数据 ;无条件多表插入的基本语法为
INSERT [ALL]
INTO table1 VALUES(column1,column2[,…])
INTO table2 VALUES(column1,column2[,…])
……
subquery;
例:利用无条件多表插入,将emp表中工资高于2000的员工信息查询后分别插入emp_sal和emp_mgr表。;有条件多表插入语法为
INSERT ALL|FIRST
WHEN condition1 THEN INTO table1(column1[,…])
WHEN condition2 THEN INTO table2(column1[,…])
……
ELSE INTO tablen(column1[,…])
subquery;
其中,
ALL:表示一条记录可以同时插入多个满足条件的表中;
FIRST:表示一条记录只插入第一个满足条件的表中。;例:将emp表中的员工信息按不同部门号分别复制到emp10,emp20,emp30和emp_other表中。 ;例:将emp表中员工信息按照不同部门号分别复制到emp10,emp20,emp30和emp_other表中。同时,将工资低于2000的员工信息复制到lowsal表中,将工资高于4000的员工信息复制到highsal表中,将工资在2000~3000之间的员工信息复制到middlesal表中。;多表插入的应用
利用多表插入技术可以实现不同数据源之间的数据转换,可以将非关系数据库的一条记录转换为关系数据库中的多条记录。
例:将SALE_SOURCE_DATA表中的记录转换为SALE_INFO表中的记录。;SQL CREATE TABLE sale_info(
emp_id NUMBER(6),
week NUMBER(2),
sale NUMBER(8,2));
SQL INSERT ALL
INTO sale_info VALUES (emp_id,week_id,sale_MON)
INTO sale_info VALUES (emp_id,week_id,sale_TUE)
INTO sale_info VALUES (emp_id,week_id,sale_WED)
INTO sale_info VALUES (emp_id,week_id,sale_THUR)
INTO sale_info VALUES (emp_id,week_id, sale_FRI)
SELECT * FROM sale_source_data; ;4.2 修改数据;基本语法
UPDATE table_name|view_name
SET column1=value1[,column2=value2…]
[WHERE condition]
修改单条记录。
例33:将员工号为7844的员工工资增加100,奖金修改为200。
修改多条记录
利用子查询修改记录;4.3 删除数据;基本语法
DELETE FROM table|view [WHERE condition]
删除单条记录
删除多条记录
带有子查询的删除操作
;利用TRUNCATE删除数据
TRUNCATE TABLE table_name
TRUNCATE与DELETE区别
TRUNCATE释放存储空间;DELETE只标记为UNUSED,不释放空间。
TRUNCATE不写入日志文件,因此执行效率较高,但该操作不可回滚。 ;事务;1. 事务概述;(2) 事务的
文档评论(0)