Oracle SQL Lesson (9) - 操作数据(增删改)
使用INSERT语句
INSERT INTO table [(column [, column...])]
VALUES (value [, value...]);
INSERT INTO departments(department_id,
department_name, manager_id, location_id)
VALUES (70, 'Public Relations', 100, 1700);
字符和日期需要用单引号
INSERT INTO employees
VALUES (114,
'Den', 'Raphealy',
'DRAPHEAL', '515.127.4561',
TO_DATE('FEB 3, 1999', 'MON DD, YYYY'),
'SA_REP', 11000, 0.2, 100, 60);
insert into d values(50, 'SHC','America');
insert into d values(60, 'IT','China');
插入默认值或空值
INSERT INTO departments (department_id,
department_name)
VALUES (30, 'Purchasing');
INSERT INTO departments
VALUES (100, 'Finance', NULL, NULL);
insert.sql
INSERT INTO d VALUES(&dno, '&dname','&loc');
@/u01/app/oracle/insert.sql
使用子查询插入
INSERT INTO sales_reps(id, name, salary, commission_pct)
SELECT employee_id, last_name, salary, commission_pct
FROM employees
WHERE job_id LIKE '%REP%';
不使用values子句
drop table e purge;
create table e as select * from emp where 1=2;
insert into e select * from emp where deptno = 10;
insert into e select * from emp where deptno = 20;
insert into e (empno,ename,sal,deptno) select empno,ename,sal,deptno from emp where deptno=30;
alter table e modify job default 'WWW';
使用UPDATE语句
UPDATE table
SET column = value [, column = value, ...]
[WHERE condition];
UPDATE employees
SET department_id = 50
WHERE employee_id = 113;
UPDATE copy_emp
SET department_id = 110;
Specify SET column_name= NULL to update a column value to NULL.
UPDATE copy_emp
SET department_id = (SELECT department_id
FROM employees
WHERE employee_id = 100)
WHERE job_id = (SELECT job_id
FROM employees
WHERE employee_id = 200);
使用DELETE(DML)语句和Truncate(DDL)语句
DELETE [FROM] table
[WHERE condition];
create table emp_copy as select * from employees;
DELETE FROM emp_copy
WHERE department_id =
(SELECT department_id
FROM departments
WHERE department_name
LIKE '%Public%');
TRUNCATE TABLE table_name;
TRUNCATE TABLE copy_emp;
自动提交,不能回滚。不能加where子句。产生日志少,几乎不产生undo数据,速度快。会释放空间,delete后不会释放空间。
conn / as sysdba;
grant select on v_$database to scott;
grant select on dba_objects to scott;
conn scott/tiger;
create table big_t as select * from dba_objects;
exec dbms_status.gather_table_stats('scott','big_t');
select blocks,num_rows from user_tables where table_name='BIG_T';
delete big_t;
commit;
exec dbms_status.gather_table_stats('scott','big_t');
select blocks,num_rows from user_tables where table_name='BIG_T';
drop table big_t purge;
create table big_t as select * from dba_objects;
exec dbms_status.gather_table_stats('scott','big_t');
select blocks,num_rows from user_tables where table_name='BIG_T';
truncate table big_t;
exec dbms_status.gather_table_stats('scott','big_t');
select blocks,num_rows from user_tables where table_name='BIG_T';
事务控制
DML statements that constitute one consistent change to the data
One DDL statement
One data control language (DCL) statement
Begin when the first DML SQL statement is executed.
End with one of the following events:
-A COMMIT or ROLLBACK statement is issued.
-A DDL or DCL statement executes (automatic commit).
-The user exits SQL Developer or SQL*Plus. (Commit)
-The system crashes.(RollBack)
commit之后,其他的会话才能看到所做的更改。
session 1:
insert into d select * from d;
session 2:
select * from d;
session 1:
delete d where rownumber<=4;
session 2:
select * from d;
session 1:
create table e as select * from emp;
session 2:
select * from d;
session 1:
exit;
session 2:
select * from d;
session 1:
insert into d select * from d;
session 2:
ps -a | grep 'ora'
kill -9 4181
startup
select * from d;
使用savepoint,将一个事务分为多个部分
insert into d values(50, 'edu','china');
update d set loc='china' where deptno=40;
delete d where deptno=10;
rollback;
select * from d;
insert into d values(50, 'edu','china');
savepooint s1;
update d set loc='china' where deptno=40;
savepoint s2;
delete d where deptno=10;
rollback to savepoint s2;
select * from d;
rollback;
select * from d;
语句级别回滚
错误的语句只会回滚该语句,不会回滚之前的语句所做的更改。
读一致性
user a:
UPDATE employeesSET salary = 7000
WHERE last_name = 'Grant';
user b:
SELECT * FROM userA.employees;
select * from emp for update;
SELECT employee_id, salary, commission_pct, job_id
FROM employees
WHERE job_id = 'SA_REP'
FOR UPDATE
ORDER BY employee_id;
使用FOR UPDATE OF column_name 来确定锁定制定的行
SELECT e.employee_id, e.salary, e.commission_pct
FROM employees e JOIN departments d
USING (department_id)
WHERE job_id = 'ST_CLERK‘
AND location_id = 1500
FOR UPDATE OF e.salary
ORDER BY e.employee_id;
Oracle SQL Lesson (9) - 操作数据(增删改)的更多相关文章
- Delphi - cxGrid连接Oracle数据库 实现数据的增删改查
cxGrid连接Oracle数据库 实现数据的增删改查 cxGrid连接Oracle数据库 1:通过OraSession连接数据库.OraDataSet实现OraSession和OraDataSour ...
- python链接oracle数据库以及数据库的增删改查实例
初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...
- SQL语法之初级增删改查
SQL语法之初级增删改查 1.增 1.1插入单行 INSERT INTO [表名](列名) VALUES(列值) 语法如下: INSERT INTO bsp_Nproductclass(guid,pi ...
- oracle初试、函数、增删改查、多表查询
安装oracle后的测试以及解锁账户 安装后打开命令行,输入 sqlplus 回车后会提示输入用户名,输入 sys或者system 回车后输入密码,密码为安装or ...
- oracle学习笔记系列------oracle 基本操作之表的增删改查
--创建一个表 CREATE TABLE employee_souvc( id ), name ), gender ), birth DATE, salary ,), job ), deptno ) ...
- Sql Server——数据的增删改
所谓数据的增删改就是在创建好数据库和表后向表中添加数据.删除表中的数据.更改表中的一些数据. 新增数据: 语法一: insert into 表名 values (数据内容) --这里需要 ...
- SQL学习之简单增删改查
SQL最常用的语句,就是增删改查: 增删改查的对象,分别是库(文件夹),表(文件),表的内容(表的记录): 一.创建一个基本的表 #create table Student_Info (Name VA ...
- Python 模拟SQL对文件进行增删改查
#!/usr/bin/env python # _*_ coding:UTF-8 _*_ # __auth__: Dalhhin # Python 3.5.2,Pycharm 2016.3.2 # 2 ...
- SQL简单语句(增删改查)
简单的SQL语句增删改查操作 说明: 在mysql里面亲测结果正确 用到的表(学生表:studnets) 1.创建一个学生表,(学号,姓名,性别,家庭住址) mysql> create t ...
随机推荐
- 启动网页时候自己主动载入servlet假设不使用strus最经常使用的两种方式
这是第一种使用的是onload方法当中的test是自己的servlet <html> <body onload = "test"> </body> ...
- 排序(6)---------归并排序(C语言实现)
归并排序: 归并操作,也叫归并算法,指的是将两个已经排序的序列合并成一个序列的操作.归并排序算法依赖归并操作. 归并操作的步骤例如以下: (1) 申请空间,使其大小为两个已经排序序列之和.该空 ...
- OpenCV-Python教程(4、形态学处理)
提示: 转载请详细注明原作者及出处,谢谢! 本文介绍使用OpenCV-Python进行形态学处理 本文不介绍形态学处理的基本概念,所以读者需要预先对其有一定的了解. 定义结构元素 形态学处理的核心就是 ...
- 使用HtmlAgilityPack批量抓取网页数据
原文:使用HtmlAgilityPack批量抓取网页数据 相关软件点击下载登录的处理.因为有些网页数据需要登陆后才能提取.这里要使用ieHTTPHeaders来提取登录时的提交信息.抓取网页 Htm ...
- WinCE隐藏显示任务栏,当任务栏隐藏时将其显示,当任务栏显示时将其隐藏(FindWindow,ShowWindow,IsWindowVisible),
HANDLE hWndTaskBar = ::FindWindow(TEXT("HHTaskBar"), NULL); if(::IsWindowVisible(hWndTask ...
- LVS的调度算法分析
LVS调度算法 一.静态调度算法 1. rr(round robin)轮询调度,即调度器将客户端的请求依次的传递给内部的服务器,从1到N,算法简洁,无须记录状态,但是不考虑每台服务器的性能. 配置如 ...
- 联系我们_鲲鹏Web数据抓取 - 专业Web数据采集服务提供者
联系我们_鲲鹏Web数据抓取 - 专业Web数据采集服务提供者 首页 > 联系我们 我们的联系方式如下: 029 - 82542052(陕西 西安) 13389148466 或 13571845 ...
- UltraEdit破解方法最强收录
作为一个能够满足你一切编辑需求的强大文本编辑器.ultraedit在IT届有着非常高的人气.只是它正版的价钱也是不廉价滴,没记错的话是要好几十刀. 那么对于我们来说,破解UltraEdit就是一项必备 ...
- document.write()相关
原文地址:http://www.cnblogs.com/dh616854836/articles/2140349.html document.write()脚本向窗口(不管是本窗口或其他窗口)写完内容 ...
- hdu2844(多重背包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2844 题意:一位同学想要买手表,他有n种硬币,每种硬币已知有num[i]个.已知手表的价钱最多m元,问 ...