web-dev-qa-db-fra.com

Comment changer le fichier de sauvegarde de répertoire dans impdp?

J'utilise impdp pour importer une sauvegarde. Mais je veux changer le fichier de sauvegarde de répertoire par défaut.

$ impdp system/password@$Oracle_SID schemas=USER_SCHEMA dumpfile=mydumpfile.dmp logfile=impdpmydumpfile.log

Import: Release 11.2.0.3.0 - Production on Mon Mar 16 09:32:05 2015

Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.

Connected to: Oracle Database 11g Release 11.2.0.3.0 - 64bit Production
ORA-39001: invalid argument value
ORA-39000: bad dump file specification
ORA-31640: unable to open dump file "/u01/app/Oracle/admin/mydatabase/dpdump/mydumpfile.dmp" for read
ORA-27037: unable to obtain file status
Linux-x86_64 Error: 2: No such file or directory
Additional information: 3
8
acfreitas

Avec le paramètre directory :

impdp system/password@$Oracle_SID schemas=USER_SCHEMA directory=MY_DIR \
  dumpfile=mydumpfile.dmp logfile=impdpmydumpfile.log

Le répertoire default est DATA_PUMP_DIR, qui est probablement défini sur /u01/app/Oracle/admin/mydatabase/dpdump sur votre système.

Pour utiliser un autre répertoire, vous (ou votre DBA) devrez créer un nouvel objet de répertoire dans la base de données, qui pointe vers le répertoire du système d'exploitation visible par Oracle dans lequel vous avez placé le fichier et attribuez des privilèges à l'utilisateur l'importation.

13
Alex Poole

Je veux changer le fichier de sauvegarde du répertoire par défaut.

Vous pouvez créer un nouveau répertoire et lui attribuer les privilèges requis, par exemple:

SQL> CREATE DIRECTORY dmpdir AS '/opt/Oracle';
Directory created.

SQL> GRANT read, write ON DIRECTORY dmpdir TO scott;
Grant succeeded.

Pour utiliser le répertoire nouvellement créé, vous pouvez simplement l'ajouter en tant que paramètre:

DIRECTORY=dmpdir

Oracle a introduit un répertoire par défaut de 10g R2 , appelé DATA_PUMP_DIR , pouvant être utilisé. Pour vérifier l'emplacement, vous pouvez regarder dans dba_directories :

SQL> select DIRECTORY_NAME, DIRECTORY_PATH from dba_directories where DIRECTORY_NAME = 'DATA_PUMP_DIR';

DIRECTORY_NAME       DIRECTORY_PATH
-------------------- --------------------------------------------------
DATA_PUMP_DIR        C:\app\Lalit/admin/orcl/dpdump/

SQL>
4
Lalit Kumar B

utilisez l'option REPERTOIRE.

Documentation ici: http://docs.Oracle.com/cd/E11882_01/server.112/e22490/dp_import.htm#SUTIL907

  DIRECTORY

  Default: DATA_PUMP_DIR

  Purpose

  Specifies the default location in which the import job can find the dump file set and where it should create log and SQL files.

  Syntax and Description

  DIRECTORY=directory_object
  The directory_object is the name of a database directory object (not the file path of an actual directory). Upon installation, privileged users have access to a default directory object named DATA_PUMP_DIR. Users with access to the default DATA_PUMP_DIR directory object do not need to use the DIRECTORY parameter at all.

  A directory object specified on the DUMPFILE, LOGFILE, or SQLFILE parameter overrides any directory object that you specify for the DIRECTORY parameter. You must have Read access to the directory used for the dump file set and Write access to the directory used to create the log and SQL files.

  Example

  The following is an example of using the DIRECTORY parameter. You can create the expfull.dmp dump file used in this example by running the example provided for the Export FULL parameter. See "FULL".

  > impdp hr DIRECTORY=dpump_dir1 DUMPFILE=expfull.dmp 
  LOGFILE=dpump_dir2:expfull.log
  This command results in the import job looking for the expfull.dmp dump file in the directory pointed to by the dpump_dir1 directory object. The dpump_dir2 directory object specified on the LOGFILE parameter overrides the DIRECTORY parameter so that the log file is written to dpump_dir2.
4
Ditto

Vous pouvez utiliser la commande suivante pour mettre à jour le chemin DATA PUMP DIRECTORY,

create or replace directory DATA_PUMP_DIR as '/u01/app/Oracle/admin/MYDB/dpdump/';

Pour moi, la correction du chemin des données était nécessaire car j'ai restauré la base de données de la production à l'environnement de test.

La même commande peut être utilisée pour créer un nouveau DATA PUMP DIRECTORYname et path.

2
user3141985