• oracle 导入/导出遇到的 问题总结


    0925: 解决oracle 11g空数据 exp 少表的问题

    1:生成处理语句

    Select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 ; 

    2:alter system set deferred_segment_creation=false; 

    只能对新表起作用

     

    20130613:

    10g中的表用10的客户端导出来后,用11g的客户端导入到10g的库中 大字段会报错;用10g的客户端,导入到10g的服务器中正常

     

    1: oracle 11g 导出,如果一个表中数据为空,导出时将不导出这张表;可以设置oracle参数修改,但只对新的表起作用;(今天把每个空白表多了一条数据)

    2:oracle 11g中exp 导出的数据,在10g版本的imp中不能识别; 低版本导出的数据,高版本能够识别;

    3:删除 用户 及用户的表数据

    drop user dsfa cascade;

    4:查看某个用户具有的表数据

    Select * From USER_TABLES;

    5: oracle 创建表空间

     

    /*分为四步 */
    /*第1步:创建临时表空间  */
    create temporary tablespace user_temp 
    tempfile 'D:oracleoradataOracle9iuser_temp.dbf'
    size 50m 
    autoextend on 
    next 50m maxsize 20480m 
    extent management local
      
    /*第2步:创建数据表空间  */
    create tablespace test_data 
    logging 
    datafile 'D:oracleoradataOracle9iuser_data.dbf'
    size 50m 
    autoextend on 
    next 50m maxsize 20480m 
    extent management local
      
    /*第3步:创建用户并指定表空间  */
    create user username identified by password 
    default tablespace user_data 
    temporary tablespace user_temp; 
      
    /*第4步:给用户授予权限  */
    grant connect,resource,dba to username;

     

    6: 如果一个表中包含clob字段,pl/sql能够导出成功,但是不能导入...包含clob的表需要用imp 命令导入

    7: oracle exp imp 使用方法

     

    exp 命令:

    1 exp username/psw@TEST file=d:test.dmp full=y

    2 exp username/psw@TEST file=d:test.dmp owner=(ly)

    3 exp username/psw@TEST file= d:test.dmp tables=(grid1,grid2)

    1 其中一是将 Test(与某一数据库对应的 oracle 服务名)数据库进行整体导出

    2 将属于用户 ly 的所有表导出

    3 将表 grid1,与 grid2 导出

     

    imp 命令:

    1 imp system/psw@TEST file=d:test.dmp

    2 imp system/psw@TEST full=y file=d:test.dmp ignore=y

    3 imp system/psw@TEST file=d:test.dmp tables=(grid1)

     

    ignore=y 表示如果被导入的数据库中 某个表已经存在就忽略不导入那个表

    3 表示只导入 grid1 这个表

     

    cmd 下执行 用 exp/imp 远程操作数据库 对 ORACLE 数据库进行远程操作,假设数据库在 192.168.1.110 上,具体方法如下:

    一、在客户端创建和服务端对应的服务名

    方法1: 修改 tnsnames.ora 文件 加入远程服务器的命名:

    TEST_ORCL = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.110)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = orcl) ) )

    方法 2: 在 oracle 客户端,打开 net manager。 创建一个服务命名 TEST_ORCL,主机 IP 为:192.168.1.110,服务名 orcl,端口 1521

    二、测试远程服务器是否畅通

    进入到 cmd 后,执行命令:tnsping TEST_ORCL。

    三、远程操作数据库 导出

    1:exp username/password@TEST_ORCL file=bak_filepath

    2:exp username/password@TEST_ORCL full=y file=bak_filepath      

    username 用户名,password 密码,TEST_ORCL 客服端服务名

    bak_filepath 备份文件存放 的路径 导入:

    1:imp username/password@TEST_ORCL file=bak_filepath full=y

    2:imp username/password@TEST_ORCL/database_name file=bak_filepath full=y

    3:imp username/password@TEST_ORCL file=bak_filepath fromuser=fromadmin touser=toadmin

    username 用户名, password 密码,

    TEST_ORCL 客服端服务名 bak_filepath 备份文件存放 的路径

    fromadmin 备份数据的用户名  toadmin 还原数据库的用户名。

  • 相关阅读:
    目标检测中roi的有关操作
    JavaScript高级程序设计读后感(一)
    手机app后台初学
    DTO数据传输对象
    数据库设计系列之四--ER图
    数据库设计系列之三
    数据库设计系列之二
    数据库设计系列之一
    Linux命令大全
    Linux登录密码修改
  • 原文地址:https://www.cnblogs.com/baiduligang/p/4247596.html
Copyright © 2020-2023  润新知