第一篇:黑马程序员c语言教程:子查询简介
--为什么要用子查询
先求scott的工资
select sal from emp
where ename='SCOTT'
select *
from emp
where sal > 3000
//===>
select *
from emp
where sal >(select sal from emp
where ename='SCOTT')
/
子查询的场景
对于一个问题,1步不能求解,需要多步
where ename='SCOTT')子查询的本质 select语言的嵌套
子查询知识架构
合理的书写风格
子查询的()不要丢掉
子查询和主查询可以不是同一张表,只要子查询返回的结果,主查询能用就行...4 可以在主查询的什么地方放一个子查询
select a, b, c,(select *......)//ok //在select后面的子查询 必须是单行子查询
from tab1, tab2,(select **)//ok
where...(select *...)//ok
order by...//err
group by...//err
havning...(select ****)//
子查询的分类
按照子查询返回的条目数,分为: 单行子查询和多行子查询
--单行子查询只能用单行比较操作符(= <>)
--多行子查询只能用多行比较操作符(in any all)
按照子查询和主查询的执行顺序来分
一般子子查询 子查询把结果返回给主查询....一般
相关子查询 主查询把select列中的参数传递给 子查询
子查询返回空值的问题
子查询中一般不使用order by,但是Top-N问题,子查询必须要用order by
eg: 求工资的前三名 分页....M<=x<=N
子查询结果集一般不排序 ,Top-N问题除外
解释3-eg 查询部门名称是SALES 的员工信息
分析思路: 因为SALES在部门表中,,查找部门表,才能获取部门编号,.....===>员工信息
//子查询
select *
from emp
where deptno =(select deptno
from dept
where dname='SALES')
//多表查询
select e.*
from emp e, dept d
where e.deptno = d.deptno and d.dname = 'SALES'
SQL优化
select *
select a, b, c, from....//效率高
// 多表查询 效率高
解释4-1
select empno, ename, sysdate, 'ddddd',(select dname from dept where deptno=10)十号部门名称
from emp
select empno, ename, sysdate, 'ddddd',(select dname from dept)十号部门名称
from emp
第 1 行出现错误:
ORA-01427: 单行子查询返回多个行
解释4-2
---from是一个集合,tab表 本身就是I个集合 select a, b, c,from(select *......)//ok //在select后面的子查询 必须是单行子查询
查询员工名字 编号
select *
from
___________________
select *
from
(select empno, ename from emp)
解释5-1
--单行子查询只能用单行比较操作符(= <>)ppt
select *
from emp
where sal >(select sal from emp
where ename='SCOTT')
解释5-2 多行子查询 多行比较操作符
in
--查询部门名称为 SALES 和 ACCOUNTING 的员工信息
--查询部门名称为 不是 SALES 和 ACCOUNTING 的员工信息
select *
from emp
where deptno in(select deptno from dept where dname='SALES' or dname='ACCOUNTING')
select *
from emp
where deptno not in(select deptno from dept where dname='SALES' or dname='ACCOUNTING')
all any
--查询薪水 比30号部门 所有员工薪高的员工信息 all
select *
from emp
where sal >(select max(sal)from emp where deptno = 30)
select *
from emp
where sal > all(select sal from emp where deptno = 30)
--大于这个集合的最大值 就可以
--查询薪水 比30号部门 任意一个员工薪高的员工信息
select *
from emp
where sal >(select min(sal)from emp where deptno = 30)
select *
from emp
where sal > any(select sal from emp where deptno = 30)
--大于这个集合的最小值 就可以
--any/all的运算 和 前面的逻辑比较运算 相互关联
解释6 有关子查询中的空值 not in(10, 20, null)--查询不是经理的员工信息
--思路 先按照: 查询是经理的员工信息
分析1 是经理的员工信息 1
select *
from emp
where empno in(select mgr from emp)
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----------------------------------------------------------------------------------
7566 JONES MANAGER 7839 02-4月-81 2975 20
7698 BLAKE MANAGER 7839 01-5月-81 2850 30
7782 CLARK MANAGER 7839 09-6月-81 2450 10
7788 SCOTT ANALYST 7566 19-4月-87 3000 20
7839 KING PRESIDENT 17-11月-81 5000 10
7902 FORD ANALYST 7566 03-12月-81 3000 20 2
select *
from emp
where empno not in(select mgr from emp)
select *
from emp
where empno not in(select mgr from emp where mgr is not null)
//------------面试强化
第二篇:黑马程序员c语言教程:多表查询
笛卡尔积
部门表
笛卡尔积产生结果: 行数 两个表相乘
列数: 行数相加 原因
条件等值连接
select ****
from tab1, tab2
where tab1.a = tab2.a
select count(e.ename)
from emp e, dept d
3* where e.deptno = d.deptno
SQL> /
COUNT(E.ENAME)
--------------
多表查询关键点:
等值连接 eg:查询员工信息,员工号,姓名,月薪,部门名称
select e.empno, e.ename, e.sal, d.dname
from emp e, dept d
3* where e.deptno = d.deptno
SQL> /
EMPNO ENAME SAL DNAME
--------------------------------------------
7369 SMITH 800 RESEARCH
7499 ALLEN 1600 SALES
7521 WARD 1250 SALES
7566 JONES 2975 RESEARCH
7654 MARTIN 1250 SALES
7698 BLAKE 2850 SALES
7782 CLARK 2450 ACCOUNTING
7788 SCOTT 3000 RESEARCH
7839 KING 5000 ACCOUNTING
7844 TURNER 1500 SALES
7876 ADAMS 1100 RESEARCH
7900 JAMES 950 SALES
7902 FORD 3000 RESEARCH
7934 MILLER 1300 ACCOUNTING
已选择14行。
不等值连接: eg:查询员工信息,员工号,姓名,月薪, 薪水级别
select e.empno, e.ename, e.sal, s.grade from emp e, salgrade s where e.sal >= s.losal and e.sal <=s.hisal
select e.empno, e.ename, e.sal, s.grade from emp e, salgrade s where e.sal between s.losal and s.hisal
外连接 eg:按部门统计员工人数: 部门号 部门名称 各部门人数
分析1: 10 20 30 ====> 分组
分析2: 因为各部门人数 是在员工表中..多表查询
步骤1
select d.deptno, d.dname, count(e.empno)
from dept d, emp e
where d.deptno = e.deptno
group by d.deptno, d.dname
DEPTNO DNAME COUNT(E.EMPNO)
-------------------------------------
ACCOUNTING 3
RESEARCH 5
SALES 6
步骤2 外连接....分析:为什么40号部门没有统计出来
原因: 因员工表里面 没有40号部门的员工(现象)
where d.deptno = e.deptno(sql)问题的本质
40 =====>期望: 在连接条件不成立的条件下,也要把部门编号40 给显示出来....外连接...select d.deptno, d.dname, count(e.empno)
from dept d, emp e
where d.deptno = e.deptno(+)
group by d.deptno, d.dname
左外连接:(+)写在=号的右边
自连接:--查询员工信息 ,老板信息
显示: ****的老板是**** 自连接: 把一张表看成两张表,自连接
--员工表的老板 是 老板表的员工
select e.ename, b.ename
from emp e, emp b
where e.mgr = b.empno
select e.ename|| '的老板是' || b.ename
from emp e, emp b
where e.mgr = b.empno
====> 需求 把员工表的每一条记录都显示出来
select e.ename|| '的老板是' || b.ename
from emp e, emp b
where e.mgr = b.empno(+)
select e.ename|| '的老板是' || nvl(b.ename, '他自己')
from emp e, emp b
where e.mgr = b.empno(+)
SMITH的老板是FORD
MPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO----------------------------------------------------------------------------7369 SMITH CLERK 7902 17-12月-80 800 20 7499 ALLEN SALESMAN 7698 20-2月-81 1600 300 30 7521 WARD SALESMAN 7698 22-2月-81 1250 500 30 7566 JONES MANAGER 7839 02-4月-81 2975 20 7654 MARTIN SALESMAN 7698 28-9月-81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月-81 2850 30 7782 CLARK MANAGER 7839 09-6月-81 2450 10 7788 SCOTT ANALYST 7566 19-4月-87 3000 20 7839 KING PRESIDENT 17-11月-81 5000 10 7844 TURNER SALESMAN 7698 08-9月-81 1500 0 30 7876 ADAMS CLERK 7788 23-5月-87 1100 20 7900 JAMES CLERK 7698 03-12月-81 950 30 7902 FORD ANALYST 7566 03-12月-81 3000 20 7934 MILLER CLERK 7782 23-1月-82 1300 10
14行。
第三篇:黑马程序员c语言教程:Oracle简介
9.通过子查询建表 通过子查询建表的例子
SQL>CREATE TABLE emp_41 AS SELECT id, last_name, userid, start_date FROM s_emp WHERE dept_id = 41;SQL> CREATE TABLE A as select * from B where 1=2;只要表的结构.10.用子查询建表的注意事项
可以关连多个表及用集合函数生成新表,注意选择出来的字段必须有合法的字段名称,且不能重复。
用子查询方式建立的表,只有非空NOT NULL的约束条件能继承过来, 其它的约束条件和默认值都没有继承过来.根据需要,可以用alter table add constraint ……再建立其它的约束条件,如primary key等.11.Foreign Key的可选参数ON DELETE CASCADE 在创建Foreign Key时可以加可选参数: ON DELETE CASCADE它的含义是如果删除外键主表里的内容,子表里相关的内容将一起被删除.如果没有ON DELETE CASCADE参数,子表里有内容,父表里的主关键字记录不能被删除掉.12.如果数据库表里有不满足的记录存在,建立约束条件将不会成功.13.给表创建和删除同义词的例子 SQL> CREATE SYNONYM d_sum 2 FOR dept_sum_vu;SQL> CREATE PUBLIC SYNONYM s_dept 2 FOR alice.s_dept;SQL> DROP SYNONYM s_dept;
十、ORACLE里的数据字典
1.什么是数据字典?ORACLE的数据字典是数据库的重要组成部分之一,它随着数据库 的产生而产生, 随着数据库的变化而变化, 体现为sys用户下所有的一些表和视图.2.数据字典里存了以下内容: 用户信息
用户的权限信息
所有数据对象信息表的约束条件统计分析数据库的视图等 不能手工修改数据字典里的信息.16
J2EE @ zxw 3.常用的数据字典
Dictionary 存放所有数据表,视图,同义词名称和解释 Dict_columns 数据字典里字段名称的和解释 Dba_users 用户 Dba_tablespaces 表空间
Dba_data_files 数据库的文件 Dba_free_space 空闲表空间 Dba_rollback_segs 回滚段
User_objects 数据对象 User_constraints 约束条件 User_sequences 序列号 User_views 视图 User_indexes 索引 User_synonyms 同义词
Session_roles 用户的角色 User_role_privs 用户的角色权限 User_sys_privs 用户的系统权限 User_tab_privs 用户的表级权限 V$session 实时用户情况 V$sysstat 实时系统统计 V$sesstat 实时用户统计 V$sgastat 实时SGA使用 V$locked_object 实时锁 V$controlfile 控制文件 V$logfile 日志文件 V$parameter 参数文件 4.数据字典的分类 数据字典四大类别
User_ 用户下所有数据库对象
All_ 用户权限范围内所有的数据库对象 Dba_ 所有的数据库对象
V$Content$nbsp;统计分析数据库的视图 赋于oem_monitor权限非DBA用户也可查询V$*视图
5.查询数据字典
SQL> select * from dictionary where instr(comments,'index')>0;SQL> select constraint_name, constraint_type, 2 search_condition, r_constraint_name 3 from user_constraints 4 where table_name = ‘&table_name';十一.控制数据、INSERT(往数据表里插入记录的语句)SQL> insert into 表名(字段名1, 字段名2, ……)values(值1, 值2, ……);SQL> insert into 表名(字段名1, 字段名2, ……)select(字段名1, 字段名2, ……)from 另外的表名 where 条件;可以用&标记变量的方法多次输入记录
快速插入数据的方法, 一般用于大于128M的数据转移 SQL> insert /*+ append */ into 表名
select * from 另外的用户名.另外的表名 WHERE 条件;SQL> commit;注意事项:
用INSERT /*+ APPEND */ 的方法会对target_tablename产生级别为6的独占锁,如果运行此命令时还有对target_tablename的DML操作会排队在它后面, 对OLTP系统在用的表操作是不合适的。17
J2EE @ zxw 2.插入字符串类型的字段的注意事项: 字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’
如果字段值里包含单引号’ 需要进行字符串转换, 我们把它替换成两个 单引号’ ’
字符串类型的字段值超过定义的长度会出错, 最好在插入前进行长度校验 ‘’ 标记是NULL, user 标明当前用户
日期字段的字段值可以用当前数据库的系统时间SYSDATE, 精确到秒
用字符串转换成日期型函数TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)TO_DATE()还有很多种日期格式, 可以参看ORACLE DOC.年-月-日 小时:分钟:秒 的格式YYYY-MM-DD HH24:MI:SS NSERT时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型, 方法借用ORACLE里自带的DBMS_LOB程序包.3、UPDATE(修改数据表里记录的语句)SQL> UPDATE 表名 SET 字段名1=值1, 字段名2=值2, …… WHERE 条件;如果修改的值N没有赋值或定义时, 将把原来的记录内容清为NULL, 最好在修改前进行非空校验;值N超过定义的长度会出错, 最好在插入前进行长度校验.新功能,可以修改子查询后的结果集
例子:SQL> update(select * from s_dept)set id=50 where id=60;
4、DELETE(删除数据表里记录的语句)SQL> DELETE FROM 表名 WHERE 条件;注意:删除记录并不能释放ORACLE里被占用的数据块表空间.它只把那些 被删除的数据块标成unused.如果确实要删除一个大表里的全部记录, 可以用 TRUNCATE 命令, 它可以释放占用的数据块表空间
SQL> TRUNCATE TABLE 表名;此操作不可回退.5、SQL语句的分类 数据定义语言(DDL):create、alter、drop(创建、修改结构、删除)(其他:rename)数据操纵语言(DML):insert、delete、select、update(增、删、查、改)(其他:truncate)
数据控制语言(DCL):grant、revoke(授权、回收)、set role 事务控制:commit、rollback、savepoint(其他:lock table、set constraint、set transaction)
审计控制:audit、noaudit 系统控制:alter system 会话控制:alter session 其他语句:comment(添加注释)、explain plan、analyze、validate、call
6、ORACLE里事务控制 Commit 提交事务 Rollback 回退事务
Savepoint 设置断点, 在事务中标记位置, 事务结束, 断点释放
事务结束的情况遇到commit或者rollback遇到DDL和DCL语句发现错误,如死锁用户退出
SQL*PLUS系统重启或崩溃 7.DML操作的注意事项 18
J2EE @ zxw 以上SQL语句对表都加上了行级锁, 确认完成后, 必须加上事物处理结束的命令COMMIT 才能正式生效, 否则改变不一定写入数据库里.行级锁也未能得到释放.如果想撤回这些操作, 可以用命令 ROLLBACK 复原.在运行INSERT, DELETE 和 UPDATE 语句前最好估算一下可能操作的记录范围, 应该把它限定在较小(一万条记录)范围内,.否则ORACLE处理这个事物用到很大的回退段.程序响应慢甚至失去响应.如果记录数上十万以上这些操作, 可以把这些SQL语句分段分次完成, 其间加上COMMIT 确认事物处理.太过频繁的commit不好
第四篇:黑马程序员c语言教程:DML语言简介
sql语言的类型
数据语言实现数据的crud
DML语句(Data Manipulation Language)数据库操作语言
insert update delete select DDL语言 data definition Lanaguage
create table
create view index sequence synonym同义词
truncate table DCL语言 data control language数据语言
commit rollback savetpointe
OCA认证 OCP(dba)一起考, 参加oracle的培训 2w Oracle数据库管理员认证专员(OCA):Oracle Certified Associate Oracle数据库管理员认证专家(OCP): Oracle Certified Professional
Oracle数据库管理员认证大师(OCM): Oracle Certified Master
dba linux cocos2d-x 入行 4000 8500 10000 3年 8000 1.5
1.7 10 年
...语法: INSERT INTO table [(column [, column...])] VALUES(value [, value...]);
--1 向表中插入所有列 insert into emp values(1, 'tom_111', 'clerk', 7839, sysdate, 8500, 10000, 10)
--2 向表中插入部分列
insert into emp(empno, ename, sal, comm, deptno)values(2, 'tom_222', 8502, null, 10)
--3 隐式插入空值: 没有写出的列,默认为null值
--4 显示插入空值:
--5 sql插入语言的地址符 & 取地址符后面相当于一个变量
mysql语言: preparedStatement语言
insert into emp(empno, ename, sal, comm, deptno)values(&empno, &ename, 8502, null, 10)====>输入字符串是,需要 加''
1* insert into emp(empno, ename, sal, comm, deptno)values(&empno, &ename, 8502, null, 10)
SQL> /
输入 empno 的值: 4
输入 ename 的值: 'tom_444'
原值 1: insert into emp(empno, ename, sal, comm, deptno)values(&empno, &ename, 8502, null, 10)
新值 1: insert into emp(empno, ename, sal, comm, deptno)values(4, 'tom_444', 8502, null, 10)
已创建 1 行。
SQL> /
输入 empno 的值: 5
输入 ename 的值: tom_555
原值 1: insert into emp(empno, ename, sal, comm, deptno)values(&empno, &ename, 8502, null, 10)
新值 1: insert into emp(empno, ename, sal, comm, deptno)values(5, tom_555, 8502, null, 10)
insert into emp(empno, ename, sal, comm, deptno)values(5, tom_555, 8502, null, 10)
*
=====>事物抛砖....4条数据全部都回退了..这4条数据全部都在1个事物里面
&地址符, 可以在任何sql语言中使用.在select 语言中也可以使用地址符
select * from emp
where sal >&sal
--7 批量插入数据
--一次性的将emp中所有10号部门的员工插入到emp10中
--在insert语言中使用子查询 子查询 不光用在查询套查询, 也可用在DML语句套select语句
create table emp20
as select * from emp where 1=2
insert into emp20
select * from emp where deptno = 20
有关update更新语句
UPDATE table SET column = value [, column = value,...] [WHERE condition];--列子
SQL> update emp20 set sal = 1800 , deptno = 22 where ename='SMITH'
有关删除数据
DELETE [FROM] table [WHERE condition];
eg
delete from emp20 where empno = 7369
delete emp20;
delete和truncate表区别delete逐条删除 truncate 先摧毁表再重建
delete语言是DML语言 truncate是DDL
DML语言可以闪回 做错的并且提交了.可通过闪回,撤销操作
DDL语言不可以闪回 flashback
delete是逐条删除,会产生碎片, truncate不会产生碎片
行移动功能: 要开启闪回功能,必须要开启行移动功能delete不会释放空间 truncate会delete可以回滚 truncate不可以
oracle delete快 mysql truncate快.实验: 从文件中导入数据, 通过命名delete 和 truncate删除表数据 实验
从文件中导入数据
SQL> set timing off;SQL> set feedback off;SQL> drop table testdelete purge;SQL> @c:Sql.sql;SQL> SQL> set timing on;//最后删除数据表的时候,把时间打开,记录时间
SQL> delete from testdelete;已用时间: 00: 00: 00.03
从文件中导入数据
SQL> set timing off;@c:Sql.sql;
set timing off;
select count(*)from testdelete;set timing on;//最后删除数据表的时候,把时间打开,记录时间
truncate table testdelete;已用时间: 00: 00: 00.45
事务 基本概念(db2 infomix mysql sqlserver ===>)概念
一个或者多个DML语言组成特点
要么都成功,要么都失败
特性
原子性 一致性 隔离性 持久性
事物的隔离性 多个客户端同时操作数据库的时, 要隔离他们的操作
否则:脏读 不可重复读 幻读
设置不同的搁置级别来解决oracle中的事务
事务起始标志 DML语言(oracle默认事务似是打开的, 但是不自动提交)2 事务的结束标志
提交: 显示提交commit
隐式提交
1)执行DDL语言
eg create table语言 还有I个隐式的功能
提交之前的没有提交的DML语言(insert update)
2)正常退出
回滚: 显示 rollback
隐式 掉电/宕机/非正常退出==系统出错了
事物隔离实验
create table t1(tid number, tname varchar2(20));
insert into t1(tid, tname)values(1, '111');
insert into t1 values(2, '2222');
事物隐式提交实验 ===执行DDL语言
结论====>
oracle:(oracle默认事务似是打开的, 但是不自动提交)
mysql: mysql自动提交
insert oracle事务控制--保存点
create table testsavepoint(tid number, tname varchar2(20));set feedback on
insert into testsavepoint values(1, 'tom1');insert into testsavepoint values(2, 'tom2');savepoint a;//创建一个保存点
insert into testsavepoint values(3, 'tom3a);rollback to savepoint a;
注意: 回退到savepoint a 前面插入的两条sql语句还没有提交;仍然还在一个事务里面;让事务结束的方法 显示 隐式 SQL> rollback / commit oracle数据的隔离级别问题
read only ,数据库几乎不做串行化操作,增加了read only SQL99
第五篇:黑马程序员c语言教程:DML语言强化
sql语言的类型
数据语言实现数据的crud
DML语句(Data Manipulation Language)数据库操作语言
insert update delete select DDL语言 data definition Lanaguage
create table
create view index sequence synonym同义词
truncate table DCL语言 data control language数据语言
commit rollback savetpointe
OCA认证 OCP(dba)一起考, 参加oracle的培训 2w Oracle数据库管理员认证专员(OCA):Oracle Certified Associate Oracle数据库管理员认证专家(OCP): Oracle Certified Professional Oracle数据库管理员认证大师(OCM): Oracle Certified Master
语法: INSERT INTO table [(column [, column...])] VALUES(value [, value...]);
--1 向表中插入所有列
insert into emp values(1, 'tom_111', 'enginerr', 7839, sysdate, 5000, 100, 10)--2 向表中插入部分列
insert into emp(empno, ename, job, hiredate)values(2, 'tom_2222', 'enginerr', sysdate)
--3 隐式插入空值: 没有写出的列,默认为null值--4 显示插入空值:--5 sql插入语言的地址符 & 取地址符后面相当于一个变量
mysql语言: preparedStatement语言 SQL> insert into emp(empno, ename, job, hiredate)values(&empno, &ename, &job, &hiredate);输入 empno 的值: 3
输入 ename 的值: 'tom_ccc' 输入 job 的值: 'job' 输入 hiredate 的值: '22-2月-81' 原值 1: insert into emp(empno, ename, job, hiredate)values(&empno, &ename, &job, &hiredate)新值 1: insert into emp(empno, ename, job, hiredate)values(3, 'tom_ccc', 'job', '22-2月-81')
&地址符, 可以在任何sql语言中使用.在select 语言中也可以使用地址符
SQL> select ename, job, &tt from emp;输入 tt 的值: deptno 原值 1: select ename, job, &tt from emp 新值 1: select ename, job, deptno from emp
--7 批量插入数据--创建一张表
create table emp10 as
select * from emp where 1=2;--一次性的将emp中所有10号部门的员工插入到emp10中
--在insert语言中使用子查询 子查询 不光用在查询套查询, 也可用在DML语句套select语句
insert into emp10--列完全一样,可以不写
select * from emp where deptno=10;delete from emp10;
有关update更新语句
UPDATE table SET column = value [, column = value,...] [WHERE condition];--列子
SQL> update emp10 set sal=2300 where empno=7934;
有关删除数据
DELETE [FROM] table [WHERE condition];
delete和truncate表区别
delete逐条删除 truncate先摧毁表再重建delete语言是DML语言 truncate是DDL
DML语言可以闪回 做错的并且提交了.可通过闪回,撤销操作
DDL语言不可以闪回 flashback
delete是逐条删除,会产生碎片, truncate不会产生碎片
行移动功能: 要开启闪回功能,必须要开启行移动功能delete不会释放空间 truncate会delete可以回滚 truncate不可以
oracle delete快 mysql truncate快.实验: 从文件中导入数据, 通过命名delete 和 truncate删除表数据 实验
从文件中导入数据
SQL> set timing off;SQL> set feedback off;SQL> drop table testdelete purge;SQL> @c:Sql.sql;SQL> SQL> set timing on;//最后删除数据表的时候,把时间打开,记录时间
SQL> delete from testdelete;已用时间: 00: 00: 00.03
从文件中导入数据
SQL> set timing off;@c:Sql.sql;
set timing off;
select count(*)from testdelete;set timing on;//最后删除数据表的时候,把时间打开,记录时间
truncate table testdelete;已用时间: 00: 00: 00.39
事务基本概念
概念
一个或者多个DML语言组成特点
要么都成功,要么都失败
特性
原子性 一致性 隔离性 持久性
事物的隔离性 多个客户端同时操作数据库的时, 要隔离他们的操作
否则:脏读 不可重复读 幻读
设置不同的搁置级别来解决oracle中的事务
事务起始标志 DML语言(oracle默认事务似是打开的)2 事务的结束标志
提交: 显示提交commit
隐式提交
1)执行DDL语言
eg create table语言 还有I个隐式的功能
提交之前的没有提交的DML语言(insert update)
2)正常退出
回滚: 显示 rollback
隐式 掉电/宕机/非正常退出==系统出错了 oracle事务控制--保存点
create table testsavepoint(tid number, tname varchar2(20));set feedback on
insert into testsavepoint values(1, 'tom1');insert into testsavepoint values(2, 'tom2');savepoint a;//创建一个保存点
insert into testsavepoint values(3, 'tom3a);rollback to savepoint a;
注意: 回退到savepoint a 前面插入的两条sql语句还没有提交;仍然还在一个事务里面;让事务结束的方法 显示 隐式 SQL> rollback / commit oracle数据的隔离级别问题
read only ,数据库几乎不做串行化操作,增加了read only SQL99