Open denoley opened 5 years ago
It could be possible to automate if we can obtain the definition of the remote table. Do you know if it is possible to use at least DESC BLANK_LOG4RSA@DL_BLANK_RSA
?
Yes, it is possible. You can execute this statement:
Select * from user_tab_columns@DL_BLANK_RSA
where table_name = 'BLANK_LOG4RSA'
order by column_id;
and so on.
In Oracle a have View to access to other table via dblink.
Ora2Pg generates DDL:
If i'm using oracle_fdw, correct steps would be:
create foreign table blank_log4rsa_dl_blank_ekis ( BLANK_ID VARCHAR(75), BLANK_SERIES VARCHAR(150), BLANK_NUMBER VARCHAR(150), BLANK_TYPE_ID VARCHAR(3), OLD_BLANK_STATUS VARCHAR(9), NEW_BLANK_STATUS VARCHAR(9), CHANGE_DATE timestamp, CONTRACT_NUMBER VARCHAR(150), RECORD_DATE timestamp, OPER_TYPE VARCHAR(3), OPER_SYST integer, RECORD_STATE integer, VERSION integer, BRANCH_ID VARCHAR(75), CONTRACT_ID VARCHAR(75), HOLDING_COMPANY_ID VARCHAR(25) ) server dl_blank_ekis options (table 'BLANK_LOG4RSA');
CREATE OR REPLACE VIEW blanks_v (blank_id, blank_series, blank_number, blank_type_id, old_blank_status, new_blank_status, change_date, contract_number, record_date, oper_type, oper_syst, record_state, version, branch_id, contract_id, holding_company_id) AS SELECT BLANK_ID, BLANK_SERIES, BLANK_NUMBER, BLANK_TYPE_ID, OLD_BLANK_STATUS, NEW_BLANK_STATUS, CHANGE_DATE, CONTRACT_NUMBER, RECORD_DATE, OPER_TYPE, OPER_SYST, RECORD_STATE, VERSION, BRANCH_ID, CONTRACT_ID, HOLDING_COMPANY_ID FROM blank_log4rsa_dl_blank_rsa UNION ALL SELECT BLANK_ID, BLANK_SERIES, BLANK_NUMBER, BLANK_TYPE_ID, OLD_BLANK_STATUS, NEW_BLANK_STATUS, CHANGE_DATE, CONTRACT_NUMBER, RECORD_DATE, OPER_TYPE, OPER_SYST, RECORD_STATE, VERSION, BRANCH_ID, CONTRACT_ID, HOLDING_COMPANY_ID FROM blank_log4rsa_dl_blank_ekis;