Oracle创建用户、表空间、导入导出、...命令

本文介绍了Oracle中创建表空间、用户及权限分配的方法,并详细解释了使用exp和imp命令进行数据备份与恢复的过程。同时,针对导入导出过程中常见的问题提供了具体的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//创建临时表空间 
create temporary tablespace test_temp 
tempfile 'E:\oracle\product\10.2.0\oradata\testserver\test_temp01.dbf' 
size 32m 
autoextend on 
next 32m maxsize 2048m 
extent management local; 
//创建数据表空间 
create tablespace test_data 
logging 
datafile 'E:\oracle\product\10.2.0\oradata\testserver\test_data01.dbf' 
size 32m 
autoextend on 
next 32m maxsize 2048m 
extent management local; 
//创建用户并指定表空间 
create user testserver_user identified by testserver_user 
default tablespace test_data 
temporary tablespace test_temp; 
//给用户授予权限 
grant connect,resource to testserver_user; (db2:指定所有权限) 
导入导出命令: 
Oracle数据导入导出imp/exp就相当于oracle数据还原与备份。exp命令可以把数据从远程数据库服务器导出到本地的dmp文件, imp命令可以把dmp文件从本地导入到远处的数据库服务器中。 利用这个功能可以构建两个相同的数据库,一个用来测试,一个用来正式使用。 

执行环境:可以在SQLPLUS.EXE或者DOS(命令行)中执行, 
DOS中可以执行时由于 在oracle 8i 中 安装目录ora81BIN被设置为全局路径, 
该目录下有EXP.EXE与IMP.EXE文件被用来执行导入导出。 
oracle用java编写,SQLPLUS.EXE、EXP.EXE、IMP.EXE这两个文件有可能是被包装后的类文件。 
SQLPLUS.EXE调用EXP.EXE、IMP.EXE所包裹的类,完成导入导出功能。 

下面介绍的是导入导出的实例。 
数据导出: 
1 将数据库TEST完全导出,用户名system 密码manager 导出到D:daochu.dmp中 
   exp system/manager@TEST file=d:daochu.dmp full=y 
2 将数据库中system用户与sys用户的表导出 
   exp system/manager@TEST file=d:daochu.dmp owner=(system,sys) 
3 将数据库中的表inner_notify、notify_staff_relat导出 
    exp aichannel/aichannel@TESTDB2 file= d:datanewsmgnt.dmp tables=(inner_notify,notify_staff_relat) 
4 将数据库中的表table1中的字段filed1以"00"打头的数据导出 
   exp system/manager@TEST file=d:daochu.dmp tables=(table1) query=" where filed1 like '00%'" 

上面是常用的导出,对于压缩,既用winzip把dmp文件可以很好的压缩。 
也可以在上面命令后面 加上 compress=y 来实现。 
数据的导入 
1 将D:daochu.dmp 中的数据导入 TEST数据库中。 
   imp system/manager@TEST file=d:daochu.dmp 
   imp aichannel/aichannel@HUST full=y file=d:datanewsmgnt.dmp ignore=y 
   上面可能有点问题,因为有的表已经存在,然后它就报错,对该表就不进行导入。 
   在后面加上 ignore=y 就可以了。 
2 将d:daochu.dmp中的表table1 导入 
imp system/manager@TEST file=d:daochu.dmp tables=(table1) 

基本上上面的导入导出够用了。不少情况要先是将表彻底删除,然后导入。 

注意: 
操作者要有足够的权限,权限不够它会提示。 
数据库时可以连上的。可以用tnsping TEST 来获得数据库TEST能否连上。 
附录一: 
给用户增加导入数据权限的操作 
第一,启动sql*puls 
第二,以system/manager登陆 
第三,create user 用户名 IDENTIFIED BY 密码 (如果已经创建过用户,这步可以省略) 
第四,GRANT CREATE USER,DROP USER,ALTER USER ,CREATE ANY VIEW , 
   DROP ANY VIEW,EXP_FULL_DATABASE,IMP_FULL_DATABASE, 
      DBA,CONNECT,RESOURCE,CREATE SESSION TO 用户名字 
第五, 运行-cmd-进入dmp文件所在的目录, 
      imp userid=system/manager full=y file=*.dmp 
      或者 imp userid=system/manager full=y file=filename.dmp 
执行示例: 
F:WorkOracle_Databackup>imp userid=test/test full=y file=inner_notify.dmp 
屏幕显示 
Import: Release 8.1.7.0.0 - Production on 星期四 2月 16 16:50:05 2006 
(c) Copyright 2000 Oracle Corporation. All rights reserved. 
连接到: Oracle8i Enterprise Edition Release 8.1.7.0.0 - Production 
With the Partitioning option 
JServer Release 8.1.7.0.0 - Production 
经由常规路径导出由EXPORT:V08.01.07创建的文件 
已经完成ZHS16GBK字符集和ZHS16GBK NCHAR 字符集中的导入 
导出服务器使用UTF8 NCHAR 字符集 (可能的ncharset转换) 
. 正在将AICHANNEL的对象导入到 AICHANNEL 
. . 正在导入表                  "INNER_NOTIFY"          4行被导入 
准备启用约束条件... 
成功终止导入,但出现警告。 

附录二: 
Oracle 不允许直接改变表的拥有者, 利用Export/Import可以达到这一目的. 
先建立import9.par, 
然后,使用时命令如下:imp parfile=/filepath/import9.par 
例 import9.par 内容如下: 
        FROMUSER=TGPMS       
        TOUSER=TGPMS2     (注:把表的拥有者由FROMUSER改为TOUSER,FROMUSER和TOUSER的用户可以不同)          
        ROWS=Y 
        INDEXES=Y 
        GRANTS=Y 
        CONSTRAINTS=Y 
        BUFFER=409600 
        file==/backup/ctgpc_20030623.dmp 
        log==/backup/import_20030623.log 

Oracle用imp导入用户表时选择表空间的问题 
(转:http://blog.youkuaiyun.com/tiger80/archive/2010/03/01/5335202.aspx) 
在一个数据库里把一个用户A的在表空间AA上的表 用exp导出到exp.dmp文件中,再把它导入到另一台机器上的数据库里,这时她用的是用户B,默认表空间是BB,但是用imp导入时我们发现表是导入 到了B用户下,但是还是存在了AA表空间里面,但是她需要导入到BB里,这时我们又试了好几次,都是这样。才发现自己以前都是复制过来的数据库,没有涉及 到更改表空间,于是上网查了查,幸好有好心人有解决方案。 
SQL> create user myhuang identified by myhuang default tablespace myhuang;//先创建一个用户 

SQL> grant resource,connect to myhuang; 

SQL> grant dba to myhuang;// 赋 DBA 权限 

SQL> revoke unlimited tablespace from myhuang;// 撤销此权限 

SQL> alter user myhuang quota 0 on system;// 将用户在 System 表空间的配额置为 0 

SQL> alter user myhuang quota unlimited on myhuang;// 设置在用户在 myhuang 表空间配额不受限。 

经过上述设置后,就可以用 imp 导入数据,数据将会进入指定的 myhuang 表空间: 

C:\Documents and Settings\myhuang>imp system/123456@vdb fromuser=lnxh tous 

er=myhuang file=G:\myhuang\lnxh.dmp ignore=y grants=n 

顺便说两个小问题: 

( 1 ) IMP-00003: 遇到 ORACLE 错误 1658 

ORA-01658: 无法为表空间 MYHUANG 中的段创建 INITIAL 区 

通常这个问题可以通过 Resize 增加表空间数据文件大小来解决。 

( 2 )删除表空间 

SQL> drop tablespace myhuang including contents and datafiles; 



[个人补充] 

如遇IMP -00003 : ORACLE error 1950 encountered. 

ORA-01950 : no privileges on tablespace 'XXXXXXX' 

说明你的表中有BLOB之类的字段,此类表无法导入新的表空间 

网上说9i中此问题没有完美的解决方案,估计只能先建一个同名的表空间,然后把这个表移到新的表空间中 

不知道10g和11g中是怎么样的,没有测试过 


初装oracle,创建表空间步骤: 
Oracle安装完后,其中有一个缺省的数据库,除了这个缺省的数据库外,我们还可以创建自己的数据库。 

    对于初学者来说,为了避免麻烦,可以用'Database Configuration Assistant'向导来创建数据库。 

    创建完数据库后,并不能立即在数据库中建表,必须先创建该数据库的用户,并且为该用户指定表空间。 

    下面是创建数据库用户的具体过程: 

    1.假如现在已经建好名为'news'的数据库,此时在F:\oracle\product\10.1.0\oradata\目录下已经存在news目录(注意:我的Oracle10g安装在F:\oracle下,若你的Oracle安装在别的目录,那么你新建的数据库目录就在*\product\10.1.0\oradata\目录下)。 

    2.在创建用户之前,先要创建表空间: 

    其格式为:格式:  create tablespace 表间名 datafile '数据文件名' size 表空间大小; 
    如: 
    SQL> create tablespace news_tablespace datafile 'F:\oracle\product\10.1.0\oradata\news\news_data.dbf' size 500M; 

    其中'news_tablespace'是你自定义的表空间名称,可以任意取名;'F:\oracle\product\10.1.0\oradata\news\news_data.dbf'是数据文件的存放位置,'news_data.dbf'文件名也是任意取;'size 500M'是指定该数据文件的大小,也就是表空间的大小。 



    3.现在建好了名为'news_tablespace'的表空间,下面就可以创建用户了: 

    其格式为:格式:  create user  用户名 identified by 密码  default tablespace 表空间表; 

    如: 

    SQL> create user news identified by news default tablespace news_tablespace; 

    默认表空间'default tablespace'使用上面创建的表空间。 

    4.接着授权给新建的用户: 

    SQL> grant connect,resource to news;  --表示把 connect,resource权限授予news用户 

    SQL> grant dba to news;  --表示把 dba权限授予给news用户 

    授权成功。 

    ok! 数据库用户创建完成,现在你就可以使用该用户创建数据表了!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值