Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.
Informazioni sulle impostazioni di conversione da Oracle a SQL Postgre
Le impostazioni di SQL conversione da Oracle a Postgre in DMS Schema Conversion includono quanto segue:
-
AWS DMS può convertire le viste materializzate Oracle in tabelle o viste materializzate su Postgre. SQL Per Viste materializzate scegli come convertire le viste materializzate di origine.
-
Il database Oracle di origine può utilizzare la pseudo colonna
ROWID
. Postgre SQL non supporta funzionalità simili. DMSSchema Conversion può emulare laROWID
pseudocolonna nel codice convertito utilizzando il tipo di dati o.bigint
character varying
Per farlo, scegli Usa il tipo di dati bigint per emulare la ROWID pseudocolonna o Usa il tipo di dati variabile per emulare la pseudocolonna per Row ID. ROWIDSe il codice sorgente Oracle non utilizza la pseudo colonna
ROWID
scegli Non generare. In questo caso, il codice convertito funziona più velocemente. -
Il codice sorgente Oracle può includere
TO_CHAR
, e funzioni con parametri che Postgre nonTO_DATE
supporta.TO_NUMBER
SQL Per impostazione predefinita, DMS Schema Conversion emula l'uso di questi parametri nel codice convertito.È possibile utilizzare le
TO_NUMBER
funzioni native di Postgre e SQLTO_CHAR
TO_DATE
, se il codice sorgente Oracle non dispone di parametri non supportati da Postgre. SQL In questo caso, il codice convertito funziona più velocemente. Per farlo, seleziona i seguenti valori:Usa una funzione TO_ nativa di Postgre SQL CHAR
Usa una funzione TO_ nativa di Postgre SQL DATE
Usa una funzione TO_ nativa di Postgre SQL NUMBER
-
Il database e le applicazioni possono essere eseguiti in fusi orari diversi. Per impostazione predefinita, DMS Schema Conversion emula i fusi orari nel codice convertito. Tuttavia, non è necessaria questa emulazione quando il database e le applicazioni utilizzano lo stesso fuso orario. In tal caso, seleziona Migliora le prestazioni del codice convertito se il database e le applicazioni utilizzano lo stesso fuso orario.
-
Per continuare a utilizzare le sequenze nel codice convertito, seleziona Popola le sequenze convertite con l'ultimo valore generato sul lato di origine.
-
In alcuni casi, il database Oracle di origine potrebbe archiviare solo valori interi nelle colonne con chiave primaria o esterna del tipo di dati
NUMBER
. In questi casi, AWS DMS può convertire queste colonne nel tipo diBIGINT
dati. Questo approccio migliora le prestazioni del codice convertito. A tale scopo, seleziona Converti le colonne a chiave primaria ed esterna del tipo di NUMBER dati nel tipo di BIGINT dati. Assicurati che l'origine non includa valori con virgola mobile in queste colonne per evitare la perdita di dati. -
Per ignorare i trigger e i vincoli disattivati nel codice sorgente, scegli Converti solo i trigger e i vincoli attivi.
-
È possibile utilizzare DMS Schema Conversion per convertire variabili di stringa chiamate dinamicheSQL. Il codice del database può modificare i valori di queste variabili di stringa. Per assicurarti che converta AWS DMS sempre il valore più recente di questa variabile di stringa, seleziona Converti il SQL codice dinamico creato nelle routine chiamate.
-
Le SQL versioni 10 e precedenti di Postgre non supportano le procedure. Se non hai familiarità con l'uso delle procedure in PostgreSQL, AWS DMS puoi convertire le procedure Oracle in funzioni Postgre. SQL A tale scopo, seleziona Converti procedure in funzioni.
-
Per visualizzare informazioni aggiuntive sugli elementi d'azione eseguiti, è possibile aggiungere funzioni specifiche al pacchetto di estensione. A tale scopo, seleziona Aggiungi funzioni del pacchetto di estensione che generano eccezioni definite dall'utente. Quindi scegli i livelli di gravità per generare le eccezioni definite dall'utente. Assicurati di applicare lo schema del pacchetto di estensione dopo aver convertito gli oggetti del database di origine. Per ulteriori informazioni sui pacchetti di estensione, consulta Utilizzo dei pacchetti di estensione.
-
Il database Oracle di origine può includere vincoli per i nomi generati automaticamente. Se il codice sorgente utilizza questi nomi, assicurati di selezionare Mantieni i nomi dei vincoli generati dal sistema. Se il codice sorgente utilizza questi vincoli, ma non ne usa i nomi, deseleziona questa opzione per aumentare la velocità di conversione.
-
Se i database di origine e di destinazione vengono eseguiti in fusi orari diversi, la funzione che emula la funzione integrata Oracle
SYSDATE
restituisce valori diversi rispetto alla funzione di origine. Per assicurarti che le funzioni di origine e di destinazione restituiscano gli stessi valori, scegli Imposta il fuso orario del database di origine. -
Puoi utilizzare le funzioni dell'estensione orafce nel codice convertito. Per farlo, seleziona le funzioni da usare per Routine integrate Orafce. Per ulteriori informazioni su orafce, vedere orafce on.
GitHub