質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Q&A

解決済

2回答

718閲覧

PostgreSQLで簡単に他のテーブルからCREATE TABLE INSERTしたい

y_ato

総合スコア14

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

0グッド

0クリップ

投稿2018/06/27 10:22

編集2018/06/28 07:02

現在、Oracle11からPostgreSQL9.5.1のリプレースを行っています。

Oracleで使用できていた、TABLE SELECTした結果を使って、
DBLINKを使用してCREATE TABLEするという以下のコードがあります。

CREATE TABLE TABLE_A AS (SELECT * FROM TABLE_A@DBLINK)

PostgreSQL9.5.1では、以下のように、フィールド項目・属性を指定
しないといけません。

CREATE TABLE TABLE_A AS (SELECT * FROM TABLE_A@DBLINK)
AS T1(ID1 integer, ID2 character varying(6) )

これをDB情報から取得して行う方法はないでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

oracleのdblinnkに該当する機能は、postgres9.3からはdblinnkからfdw(Foreign Data Wrapper)として機能アップしています。

fdw自体がリンクするテーブルの属性を定義する必要があるので、create table as select ~ では、属性を指定しない記述が可能です。

これをDB情報から取得して行う方法はないでしょうか?

外部の情報とは種類の違うDBMSも当然あり得るわけで、接続するDBMSごとにそのカタログ情報を理解して組み込み判別するようなことは、普通行いません。ODBC接続なら提供されるドライバー次第なので可能な気もしますが、そこまでは行っていないようです。
ですので、dblinkでもfdwでもアクセスする情報の定義が必要になります。

投稿2018/06/27 16:06

編集2018/06/28 04:25
sazi

総合スコア25195

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

y_ato

2018/06/28 06:40 編集

開発・構築環境が PostgreSQL のバージョン9.5.1のため、 fdw(Foreign Data Wrapper)の IMPORT FOREIGN SCHEMA を利用して、 リモートテーブルを作成することができました。ありがとうございます。 https://tech-lab.sios.jp/archives/8639 https://kenpg.bitbucket.io/blog/201508/06.html ただ、リモート環境public のテーブル → ローカル環境のpublic へ 同名のテーブルがあるため、別のスキーマにリモートテーブルとして 定義できないか確認中です。 →対応可能でした。ありがとうございました。
sazi

2018/06/28 04:37

IMPORT FOREIGN SCHEMAでlocal_schemaとしてスキーマ名を指定できます。
guest

0

投稿2018/06/27 11:49

Orlofsky

総合スコア16415

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問