mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 00:03:23 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			73 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/perl
 | |
| #------------------------------------------------------------------------------
 | |
| # Project  : Oracle to Postgresql converter
 | |
| # Name     : ora2pg.pl
 | |
| # Language : perl, v5.6.1
 | |
| # OS       : linux RedHat 7.3 kernel 2.4.18-17.7.xsmp
 | |
| # Author   : Gilles Darold, gilles@darold.net
 | |
| # Copyright: Copyright (c) 2000-2002 : Gilles Darold - All rights reserved -
 | |
| # Function : Script used to convert Oracle Database to PostgreSQL
 | |
| #------------------------------------------------------------------------------
 | |
| # Version  : 2.0
 | |
| #------------------------------------------------------------------------------
 | |
| 
 | |
| BEGIN {
 | |
|         $ENV{ORACLE_HOME} = '/usr/local/oracle/oracle816';
 | |
| }
 | |
| 
 | |
| use strict;
 | |
| 
 | |
| use Ora2Pg;
 | |
| 
 | |
| # Initialyze the database connection
 | |
| my $dbsrc = 'dbi:Oracle:host=localhost;sid=TEST';
 | |
| my $dbuser = 'system';
 | |
| my $dbpwd = 'manager';
 | |
| 
 | |
| # Create an instance of the Ora2Pg perl module
 | |
| my $schema = new Ora2Pg (
 | |
| 	datasource => $dbsrc,		# Database DBD datasource
 | |
| 	user => $dbuser,		# Database user
 | |
| 	password => $dbpwd,		# Database password
 | |
| 	debug => 1,			# Verbose mode
 | |
| #	export_schema => 1,		# Export Oracle schema to Postgresql 7.3 schema
 | |
| #	schema => 'APPS',		# Extract only the given schema namespace
 | |
| 	type => 'TABLE',		# Extract table
 | |
| #	type => 'PACKAGE',		# Extract PACKAGE information
 | |
| #	type => 'DATA',			# Extract data with output as INSERT statement
 | |
| #	type => 'COPY',			# Extract data with output as COPY statement
 | |
| #	type => 'VIEW',			# Extract views
 | |
| #	type => 'GRANT',		# Extract privileges
 | |
| #	type => 'SEQUENCE',		# Extract sequences
 | |
| #	type => 'TRIGGER',		# Extract triggers
 | |
| #	type => 'FUNCTION',		# Extract functions
 | |
| #	type => 'PROCEDURE',		# Extract procedures
 | |
| #	tables => [('TX_DATA')],		# simple indexes
 | |
| #	tables => [('NDW_BROWSER_ATTRIBUTES')],	# view
 | |
| #	tables => [('TRIP_DATA')],	# Foreign key
 | |
| #	showtableid => 1,		# Display only table indice during extraction
 | |
| #	min => 1,			# Extract begin at indice 3
 | |
| #	max => 10,			# Extract ended at indice 5
 | |
| #	data_limit => 1000,		# Extract all data by dump of 1000 tuples
 | |
| #	data_limit => 0,		# Extract all data in one pass. Be sure to have enougth memory.
 | |
| );
 | |
| 
 | |
| # Just export data of the following fields from table 's_txcot'
 | |
| #$schema->modify_struct('s_txcot','dossier', 'rub', 'datapp');
 | |
| 
 | |
| #### Function to use for extraction when type option is set to DATA or COPY
 | |
| 
 | |
| 	# Send exported data directly to a PostgreSQL database
 | |
| 	#$schema->send_to_pgdb('dbi:Pg:dbname=test_db;host=localhost;port=5432','test','test');
 | |
| 
 | |
| 	# Output the data extracted from Oracle DB to a file or to STDOUT if no argument.
 | |
| 	#$schema->export_data("output.sql");
 | |
| 
 | |
| #### Function to use for extraction of other type
 | |
| 
 | |
| 	# Create the POSTGRESQL representation of all objects in the database
 | |
| 	$schema->export_schema("output.sql");
 | |
| 
 | |
| exit(0);
 | |
| 
 |