Migrar Aplicativos de Bancos de Dados PostgreSQL para o Autonomous Database

Você pode migrar instruções SQL de PostgreSQL para o Oracle SQL e executar as instruções no Autonomous Database.

Traduzir Instruções PostgreSQL para Oracle SQL

Você pode traduzir instruções SQL gravadas em PostgreSQL para o Oracle SQL e executar as instruções traduzidas no Autonomous Database.

Use DBMS_CLOUD_MIGRATION.MIGRATE_SQL para traduzir a instrução PostgreSQL para o Oracle SQL. Há variantes de procedimento e função de DBMS_CLOUD_MIGRATION.MIGRATE_SQL.

Migrar a instrução PostgreSQL para o Oracle SQL com o Procedimento MIGRATE_SQL

O exemplo a seguir aceita a instrução SQL gravada em PostgreSQL como entrada, traduz a instrução para o Oracle SQL, designa a instrução SQL traduzida para output_sql_result e imprime o resultado:

SET SERVEROUTPUT ON
   declare output_sql_result CLOB;
BEGIN
  DBMS_CLOUD_MIGRATION.MIGRATE_SQL(      
    original_sql => 'SELECT e.employee_id, e.last_name, e.salary FROM employees AS e;',
    output_sql   => output_sql_result,
    source_db    => 'POSTGRES');
    DBMS_OUTPUT.PUT_LINE (output_sql_result);
END;        
/

Output
–-------------------------------------------------------------
SELECT e.employee_id, e.last_name, e.salary FROM employees e;

O parâmetro original_sql especifica a instrução PostgreSQL.

O parâmetro output_sql armazena o SQL traduzido.

O parâmetro source_db especifica o nome do banco de dados PostgreSQL.

Consulte MIGRATE_SQL Procedimento e Função para obter mais informações.

Migrar a instrução PostgreSQL para o Oracle SQL com a Função MIGRATE_SQL

O exemplo a seguir mostra a função DBMS_CLOUD_MIGRATION.MIGRATE_SQL em uma instrução SELECT. A entrada da função é uma instrução PostgreSQL e a função retorna a instrução traduzida no Oracle SQL:

SELECT DBMS_CLOUD_MIGRATION.MIGRATE_SQL(
     'CREATE TABLE IF NOT EXISTS cars (brand VARCHAR(255), model VARCHAR(255), year INT)',
     'POSTGRES') AS output FROM DUAL;

OUTPUT
------------------------------------------------------------------------------
create table cars (brand VARCHAR2(255), model VARCHAR2(255), year NUMBER(10);

Consulte MIGRATE_SQL Procedimento e Função para obter mais informações.

Observações para executar DBMS_CLOUD_MIGRATION.MIGRATE_SQL:

Executar Instruções PostgreSQL no Autonomous Database

Você pode traduzir e executar interativamente instruções PostgreSQL no seu Autonomous Database.

Use o procedimento ENABLE_TRANSLATION para ativar a tradução em tempo real de instruções SQL gravadas em PostgreSQL. Depois de ativar a tradução em uma sessão, as instruções PostgreSQL são traduzidas automaticamente e executadas como instruções Oracle SQL, e você pode ver os resultados.

Por exemplo, depois de ativar a tradução executando ENABLE_TRANSLATION, você poderá fazer interativamente o seguinte em uma sessão:
  • Crie as tabelas. Por exemplo, crie as tabelas MOVIE e INVENTORY.

  • inserir dados em tabelas.

  • Tabelas de consulta.

  • Executar operações JOIN em tabelas. Por exemplo, é possível fazer uma junção externa esquerda em tabelas.

Para ativar a tradução com PostgreSQL e executar comandos:

  1. Conecte-se ao seu Autonomous Database usando um cliente SQL.

    Consulte Conectar-se ao Autonomous Database para obter mais informações.

    Observação

    DBMS_CLOUD_MIGRATION.ENABLE_TRANSLATION não é suportado no Database Actions e não é suportado com o Oracle APEX Service.
  2. Execute DBMS_CLOUD_MIGRATION.ENABLE_TRANSLATION para ativar a conversão de SQL em tempo real em sua sessão.
    BEGIN
     DBMS_CLOUD_MIGRATION.ENABLE_TRANSLATION('POSTGRES');
    END;
    /

    Use a consulta a seguir para verificar a linguagem de tradução SQL da sua sessão:

    SELECT SYS_CONTEXT('USERENV','SQL_TRANSLATION_PROFILE_NAME') FROM DUAL;

    Consulte ENABLE_TRANSLATION Procedimento para obter mais informações.

  3. Informe instruções PostgreSQL. Por exemplo:
    CREATE TABLE movie (film_id int, title varchar(255));
    
    Table MOVIE created.

    Isso traduz e executa automaticamente a instrução PostgreSQL CREATE TABLE.

    Você pode verificar usando o comando DESC. Por exemplo:
    DESC movie;
    
    Name        Null?     Type          
    -------     -----     ------------- 
    FILM_ID               NUMBER(38)    
    TITLE                 VARCHAR2(255)
    A tabela MOVIE é criada e os tipos de dados de cada coluna são convertidos automaticamente em tipos de dados Oracle.

    Você poderá encontrar um erro durante a conversão se a instrução SQL de entrada não for suportada. Consulte Limitações para Migração e Tradução de Instruções PostgreSQL para o Oracle SQL para obter mais informações.

  4. Insira dados na tabela MOVIE. Por exemplo:
    INSERT INTO movie (film_id, title) VALUES (123, 'Tangled');
    
    1 row inserted.
    
    INSERT INTO movie (film_id, title) VALUES (234, 'Frozen');
    
    1 row inserted.

    Verifique a inserção de dados consultando a tabela MOVIE. Por exemplo:

    SELECT * FROM movie;
    
    FILM_ID  TITLE
    –------- –--------
    123	 Tangled
    234	 Frozen
    
  5. Crie uma tabela INVENTORY:
    CREATE TABLE inventory (film_id int, inventory_id int);
    
    Table INVENTORY created.
    Você pode verificar essa etapa com o comando DESC. Por exemplo:
    DESC inventory;
    
    Name        Null?     Type          
    -------     -----     ------------- 
    FILM_ID               NUMBER(38)    
    INVENTORY_ID          NUMBER(38)
    A tabela INVENTORY é criada e os tipos de dados de cada coluna são convertidos automaticamente em tipos de dados Oracle.
  6. Insira dados na tabela INVENTORY. Por exemplo:
    INSERT INTO inventory(film_id, inventory_id) VALUES (123, 223);
    
    1 row inserted.
    
    INSERT INTO inventory(film_id, inventory_id) VALUES (234, 334);
    
    1 row inserted.

    Verifique a inserção de dados consultando INVENTORY. Por exemplo:

    SELECT * FROM inventory;
    
    FILM_ID  INVENTORY_ID
    –------- –------------
    123	 223
    234	 334
  7. Execute uma junção externa esquerda nas tabelas MOVIE e INVENTORY:
    SELECT m.film_id, m.title, inventory.inventory_id 
        FROM movie AS m LEFT JOIN inventory 
        ON inventory.film_id = m.film_id;
    
      FILM_ID  TITLE       INVENTORY_ID
    ---------- ---------- ------------
           234 Frozen      334
           123 Tangled     223
    

    Este exemplo executa um LEFT OUTER JOIN nas tabelas movie e inventory. A palavra-chave AS para aliases de tabela na cláusula FROM não é suportada no Oracle SQL. A consulta é primeiro traduzida para o Oracle SQL e, em seguida, executada na sua sessão.

  8. Use o procedimento DBMS_CLOUD_MIGRATION.DISABLE_TRANSLATION para desativar a tradução de linguagem SQL em tempo real para sua sessão.
    BEGIN
     DBMS_CLOUD_MIGRATION.DISABLE_TRANSLATION;
    END;
    /

    Isso retornará um erro se a tradução do idioma SQL não estiver ativada para sua sessão.

    Consulte DISABLE_TRANSLATION Procedimento

Você pode consultar a view V$MAPPED_SQL para listar as instruções PostgreSQL traduzidas e mapeadas na memória para instruções SQL do Oracle.

Por exemplo:

SELECT v.* 
    FROM v$mapped_sql v, dba_objects o
    WHERE v.sql_translation_profile_id = o.object_id
        AND o.object_name = 'POSTGRES'
        AND o.object_type = 'TRANSLATION PROFILE';
Consulte V$MAPPED_SQL para obter mais informações.

Migrar Arquivos PostgreSQL para o Oracle SQL

Você pode migrar um arquivo contendo instruções PostgreSQL para um arquivo contendo instruções Oracle SQL.

O procedimento DBMS_CLOUD_MIGRATION.MIGRATE_FILE traduz instruções SQL em um arquivo PostgreSQL no Object Storage e gera um novo arquivo contendo o Oracle SQL.

Como pré-requisito, faça upload de um ou mais arquivos PostgreSQL com uma extensão .sql para um local no Object Storage. Os exemplos a seguir usam o arquivo postgrestest.sql submetido a upload para o Object Storage. Consulte Colocar dados no armazenamento de objetos para obter mais informações.

Para migrar arquivos PostgreSQL para o Oracle SQL:

  1. Conecte-se à instância do Autonomous Database.

    Consulte Conectar-se ao Autonomous Database para obter mais informações.

  2. Configure o acesso ao Cloud Object Storage usando um controlador de recursos ou criando um objeto de credencial.

    Esta etapa fornece acesso ao Cloud Object Storage no qual você coloca os arquivos que está migrando:

  3. Opcionalmente, você pode listar os arquivos no Object Storage. Por exemplo:
    VAR function_list CLOB;
    SELECT object_name FROM DBMS_CLOUD.LIST_OBJECTS
       (credential_name => 'OCI$RESOURCE_PRINCIPAL', location_uri => 'https://objectstorage.region.oraclecloud.com/n/namespace/b/bucket/o/files');
    
    OBJECT_NAME
    ---------------------
    postgrestest.sql
    

    Como alternativa, se você criar uma credencial em vez do controlador de recursos, OCI$RESOURCE_PRINCIPAL, especifique o nome da credencial no parâmetro credential_name.

    Consulte Função LIST_OBJECTS para obter mais informações.

  4. Execute DBMS_CLOUD_MIGRATION.MIGRATE_FILE para migrar o arquivo PostgreSQL para o Oracle SQL:
    BEGIN
     DBMS_CLOUD_MIGRATION.MIGRATE_FILE (
         credential_name => 'OCI$RESOURCE_PRINCIPAL',
         location_uri    => 'https://objectstorage.region.oraclecloud.com/n/namespace/b/bucket/o/files/postgrestest.sql',
         source_db       => 'POSTGRES'
        );
    END;
    /

    O parâmetro credential_name especifica a credencial para acessar o URI do Cloud Object Storage. O usuário que executa DBMS_CLOUD_MIGRATION.MIGRATE_FILE deve ter o privilégio EXECUTE para o objeto de credencial usado para acessar o URI do Object Storage. Ou seja, a credencial especificada com o parâmetro credential_name. Se você usar uma credencial em vez de um controlador de recursos, especifique o nome da credencial no parâmetro credential_name.

    O parâmetro location_uri especifica o URI do arquivo de origem. O formato do URI depende do serviço Cloud Object Storage que você está usando. Consulte DBMS_CLOUD Formatos de URI para obter mais informações.

    O parâmetro source_db especifica PostgreSQL como idioma do banco de dados. Use o valor POSTGRES para traduzir arquivos PostgreSQL para o Oracle SQL.

    A execução desse comando traduz o arquivo PostgreSQL postgrestest.sql para o Oracle SQL e gera um novo arquivo com o nome original_filename_oracle.sql.

    Para este exemplo, a execução de DBMS_CLOUD_MIGRATION.MIGRATE_FILE com o arquivo de entrada postgrestest.sql gera postgrestest_oracle.sql. Após a etapa de tradução, o procedimento faz upload de postgrestest_oracle.sql para o Object Storage.

    Opcionalmente, use o parâmetro target_uri para especificar o local em que o upload do arquivo traduzido é feito. O valor padrão desse parâmetro é NULL, o que significa que o upload do arquivo traduzido é feito na mesma localização especificada no parâmetro location_uri.

    Consulte MIGRATE_FILE Procedimento para obter mais informações.

  5. Verifique se o arquivo de saída foi gerado.
    SELECT object_name FROM DBMS_CLOUD.LIST_OBJECTS (
        credential_name => 'OCI$RESOURCE_PRINCIPAL', location_uri => 'https://objectstorage.region.oraclecloud.com/n/namespace/b/bucket/o/files');
    
    OBJECT_NAME
    ---------------------
    postgrestest.sql
    postgrestest_oracle.sql
    

    Como alternativa, se você criar uma credencial em vez do controlador de recursos, OCI$RESOURCE_PRINCIPAL, especifique o nome da credencial no parâmetro credential_name.

    Consulte Função LIST_OBJECTS para obter mais informações.

Execute a consulta a seguir para exibir o conteúdo do arquivo postgrestest_oracle.sql:

SELECT UTL_RAW.CAST_TO_VARCHAR2 (DBMS_CLOUD.GET_OBJECT(
   credential_name => 'OCI$RESOURCE_PRINCIPAL', 
   object_uri => 'https://objectstorage.region.oraclecloud.com/n/namespace/b/bucket/o/files')) 
FROM dual;

UTL_RAW.CAST_TO_VARCHAR2(DBMS_CLOUD.GET_OBJECT(CREDENTIAL_NAME=>'CRED1',OBJECT_U
--------------------------------------------------------------------------------
SELECT f.film_id, f.title, inventory_id
FROM film f LEFT JOIN inventory
ON inventory.film_id = f.film_id;

Como alternativa, se você criar uma credencial em vez do controlador de recursos, OCI$RESOURCE_PRINCIPAL, especifique o nome da credencial no parâmetro credential_name.

Consulte GET_OBJECT Procedimento e Função para obter mais informações.

Limitações para Migração e Tradução de PostgreSQL Instruções para Oracle SQL

Esta seção resume as limitações para migrar instruções SQL de PostgreSQL para o Oracle SQL.

A seguinte lista de instruções PostgreSQL não é suportada ao migrar para o Autonomous Database:
  • CREATE DOMAIN
  • CREATE EXTENSION
  • CREATE DATABASE
  • CREATE TYPE
  • SET
A seguinte lista de instruções PostgreSQL é suportada com restrições:
  • ALTER TABLE: Só há suporte para ALTER TABLE ADD CONSTRAINT ao migrar para o Autonomous Database.
  • DELETE: A palavra-chave RETURNING * na instrução DELETE não é suportada no Autonomous Database. Você deve substituir a cláusula RETURNING * pela cláusula RETURNING INTO. Por exemplo, DELETE FROM tasks WHERE status = 'DONE' RETURNING *;.

    Consulte RETORNO PARA A Cláusula para obter mais informações.

  • CREATE FUNCTION: A seguir não há suporte para CREATE FUNCTION:
    • O tipo de retorno SETOF, substitua SETOF pelos tipos de retorno CURSORS ou COLLECTIONS.
    • A cláusula IMMUTABLE.
    • As declarações de parâmetro no formato FUNCTION_NAME (DATATYPE, DATATYPE).
  • ALTER FUNCTION: Os argumentos da função ALTER FUNCTION, por exemplo, RENAME TO, OWNER TO e SET SCHEMA, não são suportados.