实验验证sys和system用户全库导出的区别
我们在做逻辑数据泵全库导出的时候,有两种流行的写法,一种是sys用户导出,一种是使用system用户导出。
现在想知道二者之间有什么区别?实验验证之前不妨先思考一下:
- sys和system用户的权限区别;
- 你之前习惯使用的是哪种?当时选择的原因是?
1.准备测试环境:
Oracle 10.2.0.5
使用《模拟业务最小测试用例02》初始化数据,另外手工在sys和system用户下各自创建一些表、索引、同义词等对象。
2.测试验证:
测试命令:
--创建directory
$ mkdir -p /public/xdump
SQL> create directory xdump as '/public/xdump';
--sys用户导出全库,sys导入指定sqlfile参数,生成脚本后续对比使用
$ expdp \'/ as sysdba\' directory=xdump dumpfile=full_sys_%U.dmp logfile=full_sys.log full=y parallel=2
$ impdp \'/ as sysdba\' directory=xdump dumpfile=full_sys_%U.dmp logfile=full_sys_impdp.log full =y sqlfile=full_sys.sql
--system用户导出全库,system导入指定sqlfile参数,生成脚本后续对比使用
$ expdp system directory=xdump dumpfile=full_system_%U.dmp logfile=full_system.log full=y parallel=2
$ impdp system directory=xdump dumpfile=full_system_%U.dmp logfile=full_system_impdp.log full =y sqlfile=full_system.sql
生成的文件如下:
[oracle@rac1-server xdump]$ ls -lrth
total 801M
-rw-rw---- 1 501 1000 7.4M Jun 2 13:37 full_system_02.dmp
-rw-rw---- 1 501 1000 376M Jun 2 13:37 full_system_01.dmp
-rw-rw---- 1 501 1000 7.4M Jun 2 13:37 full_sys_02.dmp
-rw-rw---- 1 501 1000 376M Jun 2 13:37 full_sys_01.dmp
-rw-rw-rw- 1 501 1000 81K Jun 2 13:37 full_sys.log
-rw-rw-rw- 1 501 1000 81K Jun 2 13:37 full_system.log
-rw-rw-rw- 1 501 1000 18M Jun 2 13:40 full_sys.sql
-rw-rw-rw- 1 501 1000 4.9K Jun 2 13:40 full_sys_impdp.log
-rw-rw-rw- 1 501 1000 18M Jun 2 13:40 full_system.sql
-rw-rw-rw- 1 501 1000 5.0K Jun 2 13:40 full_system_impdp.log
可以通过diff命令对比full_sys.sql和full_system.sql两个文件内容:
发现创建的对象一致,文件内容不一样的都是owner本身的一些信息。
进一步通过手工创建的一些对象进行搜索,发现:
- 使用sys和system导出都可以看到system下面的对象;
- 使用sys和system导出都看不到sys下面都对象;
3.总结:
也就是说,使用sys或者system用户,二者导出全库的对象实际上本质没什么区别。
就算管理特别不规范,在SYS用户下创建了业务对象。那么使用SYSTEM和SYS两种方式默认都是导不出来的。
只是system导出一定需要输入密码,sys则不一定(本例中sys导出就没有使用密码)。
这时,有好奇的同学就会问了,那么如果想导出sys下的某些表怎么办呢?正好之前自己也遇到的一个案例:
附:本文中,手工在sys和system用户下各自创建一些表、索引、同义词等对象
#----sys 用户创建
--table&index
create table sys_test as select * from dba_objects;
create index idx_sys_test on sys_test(object_id);
--table&trigger
create table sys_emp as select * from scott.emp;
create table sys_aud_salary_history(
empno NUMBER(4),
old_sal NUMBER(7,2),
new_sal NUMBER(7,2),
change_time varchar2(50)
);
create or replace trigger tri_sys_sal after update
on sys_emp
for each row
begin
insert into sys_aud_salary_history VALUES
(:OLD.empno, :OLD.sal, :NEW.sal, TO_CHAR(SYSDATE, 'yyyy-mm-dd hh24:mi:ss'));
end;
/
--这里发现sys用户无法创建owner为sys的触发器,忽略。
--synonym
create synonym sysemp for scott.emp;
--------------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------------
#----system 用户创建
conn system/oracle
--table&index
create table system_test as select * from dba_objects;
create index idx_system_test on system_test(object_id);
--table&trigger
create table system_emp as select * from scott.emp;
create table system_aud_salary_history(
empno NUMBER(4),
old_sal NUMBER(7,2),
new_sal NUMBER(7,2),
change_time varchar2(50)
);
create or replace trigger tri_system_sal after update
on system_emp
for each row
begin
insert into system_aud_salary_history VALUES
(:OLD.empno, :OLD.sal, :NEW.sal, TO_CHAR(SYSDATE, 'yyyy-mm-dd hh24:mi:ss'));
end;
/
--synonym
create synonym systememp for scott.emp;
实验验证sys和system用户全库导出的区别的更多相关文章
- Oracle sys和system用户、sysdba 和sysoper系统权限、sysdba和dba角色的区别
sys和system用户区别 1)最重要的区别,存储的数据的重要性不同 sys所有oracle的数据字典的基表和视图都存放在sys用户中,这些基表和视图对于oracle的运行是至关重要的,由数据库自己 ...
- Oracle 修改SYS、system用户密码
Oracle 修改SYS.system用户密码 by:授客 QQ:1033553122 概念 SYS用户是Oracle中权限最高的用户,而SYSTEM是一个用于数据库管理的用户.在数据库安装完之后,应 ...
- sys和system用户的权限区别
http://blog.sina.com.cn/s/blog_869b0f460100uckp.html Oracle sys和system用户.sysdba 和sysoper系统权限.sysdba和 ...
- Oracle中sys和system用户的区别
1.数据库的启动需要以SYSDBA/SYSOPER身份登录. 2.如果在同一主机上使用IPC连接到数据库使用操作系统授权,登录任何一个用户都可以拥有as sysdba和as sysoper. 3.sy ...
- Oracle数据库sys和system用户的默认密码及如何修改密码
新安装好的Oracle数据库sys用户默认密码为change_on_install,system用户默认密码为manager. 以管理员身份登录的话,在命令行中输入 sqlplus sys/chang ...
- 【转】Oracle Sys和system用户、sysdba 和sysoper系统权
一:最重要的区别,存储的数据的重要性不同 [sys]所有oracle的数据字典的基表和视图都存放在sys用户中,这些基表和视图对于oracle的运行是至关重要的,由数据库自己维护,任何用户都不能手动更 ...
- 禁止SYS和SYSTEM用户远程登录Oracle oracle的sys和system默认密码
alter system set remote_login_passwordfile=none scope=spfile; system默认:manager sys默认:change_on_insta ...
- SYS与SYSTEM、DBA与SYSDBA的区别
SYS与SYSTEM: 1. sys 的角色是sysdba system 的角色是sysoper 2. sys 具有create database的权限 system没有该权限 3. sys可以建数据 ...
- Oracle 12c 多租户 CDB 与 PDB 级别 expdb 与 impdb(表、用户、全库)
Oracle 数据库 12 c 多租户下,如何在容器数据库 (CDB) 和可插拔数据库 (PDB) 中使用 expdb 与 impdp (数据泵) 呢? 我们一起探讨下PDB 下进行表级,用户级别,全 ...
随机推荐
- 恢复制作了系统盘的U盘
制作了系统盘的U盘通常容量会变得很小(比如用win32制作的系统盘) 此时在系统安装完成之后就要把U盘恢复,否则就无法正常使用了 步骤: 1.win+r打开程序搜索框,输入cmd打开dos窗口 2.在 ...
- nginx伪静态之try_files和rewrite讲解
服务器脚本以php为例 一.伪静态是个啥? 1.说起伪静态基本上搞web开发的人,多多少少都有了解与使用,有人会说什么时候会使用伪静态?使用原生的url地址不是蛮好的吗,确实是这样的,其实 ...
- MVC 实用构架实战(一)——项目结构搭建
一.前言 在<上篇>中,已经把项目整体结构规划做了个大概的规划.在本文中,将使用代码的方式来一一解说各个层次.由于要搭建一个基本完整的结构,可能文章会比较长.另外,本系列主要出于实用的目的 ...
- ios-静态库,动态库,framework浅析(一)
一,所谓的“库” * 所谓的“库” 库(Library)说白了就是一段编译好的二进制代码,加上头文件就可以供别人使用.什么时候我们会用到库呢? 一种情 ...
- [development][http][libhtp] suricata的http库--libhtp
首先,从文档来看, 它支持管道化的http, 也可以说过于重量级. 其次, 还没有达到产品化的稳定性. 并不是完全对应我的需求, http模块是一个整体性能相关模块. 应该按需定制更合理. 但是,功能 ...
- 在VMware运行Linux下,密码错误的原因
抱歉,没有奏效,请再试一次 密码明明是正确的,但依旧报错 原因: 密码中有大写,但键盘中的大写按键在登录界面无效,需要按住shift才能实现大写.
- 《HTTP - https》
一:HTTP 缺点? - 明文通讯(也是最受诟病的一个缺点) - 不验证对方的身份(你说你是你?你怎么证明你是你呢?) - 无法验证报文的完整性,可能已经被篡改(在挨打的边缘,来回试探) 二:HTTP ...
- GIt如何进行代码管理
一:Git账号设置(仅第一次需设置): 1.首先打开GIt Bash 界面
- localstorage 和 sessionstorage 是什么?区别是什么?
localstorage 和 sessionstorage 一样都是用来存储客户端临时信息的对象,他们均只能存储字符串类型对象: localstorage生命周期是永久的,这意味着除非用户在浏览器提供 ...
- 两个java工程之间的相互调用方法
如果你有两个java项目的话,如何向他们之间进行信息的通信前提:必须知道要通信的java项目(接收请求方)的服务器的IP地址和访问路径.其实两个java项目之间的通信还是使用HTTP的请求.主要有两种 ...