DBA必须掌握的知识基础(经典大全)

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

∙oracle恢复误删除数据,解除锁定的等sql语句

∙oracle恢复误删除数据

∙oracle相关知识

推荐群组: Database圈子

更多相关推荐

转载请注明出处:/

注意:数据库版本是10g,不过大部分9i的也适用,闪回9i就没有.

1.曾经不小心把开发库的数据库表全部删除,当时吓的要死。结果找到下面的语句恢复到了1个小时之前的数据!很简单。

注意使用管理员登录系统:

select * from 表名 as of timestamp sysdate-1/12 //查询两个小时前的某表数据!既然两小时以前的数据都得到了,继续怎么做,知道了吧。。

如果drop了表,怎么办??见下面:

drop table 表名;

数据库误删除表之后恢复:(绝对ok,我就做过这样的事情,汗)不过要记得删除了哪些表名。

flashback table 表名 to before drop;

2.查询得到当前数据库中锁,以及解锁:

查锁

SELECT /*+ rule */ ername,

decode(l.type,'TM','TABLE LOCK',

'TX','ROW LOCK',

NULL) LOCK_LEVEL,

o.owner,o.object_name,o.object_type,

s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser

FROM v$session s,v$lock l,dba_objects o

WHERE l.sid = s.sid

AND l.id1 = o.object_id(+)

AND ername is NOT NULL;

解锁

alter system kill session 'sid,serial';

如果解不了。直接倒os下kill进程kill -9 spid

ORA-28000:账户被锁定

因为密码输入错误多次用户自动被锁定.

解决办法:alter user user_name account unlock;

3.关于查询数据库用户,权限的相关语句:

Sql代码

1. 1.查看所有用户:

2.select * from dba_user;

3.select * from all_users;

4.select * from user_users;

5.

6.

7. 2.查看用户系统权限:

8.select * from dba_sys_privs;

9.select * from all_sys_privs;

10.select * from user_sys_privs;

11.

12.

13.3.查看用户对象权限:

14.select * from dba_tab_privs;

15.select * from all_tab_privs;

16.select * from user_tab_privs;

17.

18.

19.4.查看所有角色:

20.select * from dba_roles;

21.

22.

23.5.查看用户所拥有的角色:

24.select * from dba_role_privs;

25.select * from user_role_privs;

4.几个经常用到的oracle视图:注意表名使用大写.................... Sql代码

1. 1. 查询oracle中所有用户信息

2.select * from dba_user;

3. 2. 只查询用户和密码

4.select username,password from dba_users;

5. 3. 查询当前用户信息

6.select * from dba_ustats;

7. 4. 查询用户可以访问的视图文本

8.select * from dba_varrays;

9. 5. 查询数据库中所有视图的文本

10.select * from dba_views;

11.6.查询全部索引

12.select * from user_indexes;

13.查询全部表格

14.select * from user_tables;

15.查询全部约束

16.select * from user_constraints;

17.查询全部对象

18.select * from user_objects;

5.查看当前数据库中正在执行的语句,然后可以继续做很多很多事情,例如查询执行计划等等

Sql代码

1.(1).查看相关进程在数据库中的会话

2.Select a.sid,a.serial#,a.program, a.status ,

3.substr(a.machine,1,20), a.terminal,b.spid

4.from v$session a, v$process b

5.where a.paddr=b.addr

6.and b.spid = &spid;

7.

8.(2).查看数据库中被锁住的对象和相关会话

9.select a.sid,a.serial#,ername,a.program,

10.c.owner, c.object_name

11.from v$session a, v$locked_object b, all_objects c

12.where a.sid=b.session_id and

13.c.object_id = b.object_id;

14.

15.(3).查看相关会话正在执行的SQL

16.select sql_text from v$sqlarea where address =

17.( select sql_address from v$session where sid = &sid );

6.查询表的结构:表名大写!!

相关文档
最新文档