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

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

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

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

Q&A

解決済

1回答

354閲覧

同一テーブルで、最新の価格表を作成したい

yuki_0202

総合スコア1

SQL

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

0グッド

0クリップ

投稿2021/11/03 07:17

前提・実現したいこと

価格が変更になると、新らたなIDが発行されメンテナンスがされる価格表があります。
ID=NEXT_ID が最新の価格です。

ID NAME price NEXT_ID
1 Apple 100 1
2 Bana 50 3
3 Bana 200 3
4 Grapes 10 5
5 Grapes 20 6
6 Grapes 30 7
7 Grapes 40 7

この表から、次のような最新の価格表を作成しようとしています。
ID NAME price
1 Apple 100
2 Bana 200
3 Bana 200
4 Grapes 40
5 Grapes 40
6 Grapes 40
7 Grapes 40

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

4個以上のクエリを発行しており、作業が煩雑

該当のソースコード

【Q0_newprice】
SELECT Price.ID, Price.NAME, Price.price, Price.NEXT_ID
FROM Price 
WHERE Price.NEXT_ID=ID;

【Q1】
SELECT t1.ID, t2.NEXT_ID
FROM Price AS t1 INNER JOIN Price AS t2 ON t1.NEXT_ID = t2.ID;

【Q2】
SELECT t1.ID, t2.NEXT_ID
FROM Q1 AS t1 INNER JOIN Price AS t2 ON t1.NEXT_ID = t2.ID;

<実際は、Q2の作業をQ0にある該当するデータまで繰り返す>

【Q9】
SELECT t1.ID, t2.NAME, t2.price
FROM Q2 AS t1 INNER JOIN Q0 AS t2 ON t1.NEXT_ID = t2.ID;

試したこと

「副問い合わせ」や「自己参照」など試行錯誤しましたが、いい方法がみあたりませんでした

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

使用タイミングにより、複数のソフトで使用するため、SQLの記述でまとめたい。
Acsess2019 / FileMaker/SAS9.4

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

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

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

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

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

sazi

2021/11/03 08:10 編集

> 複数のソフトで使用するため、SQLの記述でまとめたい。 どのソフトでのSQL文法になるのですか? それから、価格改定の回数に制限が無いのなら固定では無理なので、自動化するならコードでのループ処理が必要です。
guest

回答1

0

ベストアンサー

欲しいのはNEXT_ID=IDの価格だと思うので、
以下のようにNEXT_ID=IDで絞り込んだものとinner joinしてやれば、
目的の表を得られると思います。

select t1.ID,t1.NAME, t2.price from Price t1 inner join ( select * from Price where NEXT_ID = ID ) t2 on t1.NAME = t2.NAME order by ID

投稿2021/11/03 09:19

nicorinpana

総合スコア55

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

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

yuki_0202

2021/11/03 10:28

スバらしいです。t1.NAME = t2.NAME とは思いもつかなかったです。 ありがとうございました。助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問