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

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

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

これはSQL文のJOINに関するタグです。リレーショナルデータベースシステムの二つ以上のテーブルを結合する際に、この構文が利用されます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Treasure Data

Treasure Dataは、米国トレジャーデータ社の提供するクラウド型のデータマネジメントサービスです。ビッグデータ処理システムを備え、AWS上にセットアップされているため、データの集収、保管、分析を容易に行うことができます。

Q&A

解決済

1回答

4718閲覧

SQL:JOINした後に Create Tableしたいが、カラム名が重複していてうまくいかない

aooo

総合スコア15

JOIN

これはSQL文のJOINに関するタグです。リレーショナルデータベースシステムの二つ以上のテーブルを結合する際に、この構文が利用されます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Treasure Data

Treasure Dataは、米国トレジャーデータ社の提供するクラウド型のデータマネジメントサービスです。ビッグデータ処理システムを備え、AWS上にセットアップされているため、データの集収、保管、分析を容易に行うことができます。

0グッド

0クリップ

投稿2018/12/23 08:32

前提・実現したいこと

ここに質問の内容を詳しく書いてください。
(例)PHP(CakePHP)で●●なシステムを作っています。
■■な機能を実装中に以下のエラーメッセージが発生しました。

発生している問題・エラーメッセージ

SQLにて二つのテーブルをjoinした後、create tableで新しいテーブルを作りたいと思っているのですが、 それぞれのテーブルに「time」という同じカラム名が存在しているため、下記のエラーが出てしまいます。 エラー:Column name 'time' specified more than once treasure data を使用していて、どうしても「time」のみスキーマの編集ができません。 解決方法ご存知の方がいらっしゃれば、ご教示いただけませんでしょうか。

該当のソースコード

create table newtable as ( SELECT * from dataframe1 as df1 left join dataframe2 as df2 on df1.id = df2.df2_id ) SQL初心者にて書き方が雑ですみません、、、 また、select後はカラム名を列挙するのがルールだと思うのですが、 今回どうしても1300列ほどのカラムを抽出したく、すべてのカラム名を記述できないので「*」にしています。

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

すべてのカラム名を記述できない

一体どんな理由ですか?

重複している状態で仮にテーブルが作成されたとして、createしたテーブルでの名称の重複はどうするつもりですか?

どうしてもというなら、一旦元のテーブルのカラム名を重複しないように変更し、のちに戻すようにするとか。

投稿2018/12/23 09:05

編集2018/12/23 09:06
sazi

総合スコア25188

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

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

aooo

2018/12/23 09:18

さっそくのご返答ありがとうございます。 すべてのカラム名を記載できない理由は、カラムが1300列ほどあるからです。 (1300個のカラム名を書くのが面倒、というか無謀なので、、) おっしゃる通り、元のカラム名を変更しようと思って試したのですが、 TreasureDataの性質上、タイムスタンプの「time」カラムのみ、カラム名の変更ができず、、 TreasureDataでの、カラム削除方法、「time」カラムの名前変更方法、もしくは他の方法でjoin後にcreate tableする方法がございましたら、ご教示いただけますと幸いです。
sazi

2018/12/23 09:23

>1300個のカラム名を書くのが面倒、というか無謀なので、、 何故無謀なんでしょう?全て手打ちするなら、タイプミスするかもしれませんが、 dbツールで、定義文や、select * で取得したものをテキストやエクセルに張り付けるなどして、カラム名を取得すれば良いだけだと思いますが。
sazi

2018/12/23 09:28

> TreasureDataの性質上、タイムスタンプの「time」カラムのみ、カラム名の変更ができず、、 詳しくは知らないのですが、そんな制約があるのですか? 以下のようなコマンド発行したらエラーになるという事ですか? ALTER TABLE name RENAME COLUMN column_name TO new_column_name
aooo

2018/12/23 15:59

saziさん> 早速のコメントありがとうございます。 カラム名をcsvで落としてコピペでできました! 1日中格闘していたので大変助かりました!! 本当にありがとうございます。 想像力働かず失礼いたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問