DBA必须掌握的知识基础(经典大全)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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.查询表的结构:表名大写!!