CREATE TABLE IF NOT EXISTS t1 (
id int(11) NOT NULL,
name,
PRIMARY KEY(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO t1 (id, name) VALUES (1, 'a');
INSERT INTO t1 (id, name) VALUES (2, 'b');
INSERT INTO t1 (id, name) VALUES (3, 'c');
INSERT INTO t1 (id, name) VALUES (4, 'd');
CREATE TABLE IF NOT EXISTS t2 (
id int(11) NOT NULL,
t1_id INT,
price INT,
PRIMARY KEY(id),
FOREIGN KEY (t1_id) REFERENCES t1(id) on update cascade on delete cascade
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO t2 (id, t1_id, price) VALUES (1, 1, 10);
INSERT INTO t2 (id, t1_id, price) VALUES (2, 1, 50);
INSERT INTO t2 (id, t1_id, price) VALUES (3, 1, 30);
INSERT INTO t2 (id, t1_id, price) VALUES (4, 1, 100);
INSERT INTO t2 (id, t1_id, price) VALUES (5, 2, 1000);
INSERT INTO t2 (id, t1_id, price) VALUES (6, 2, 3000);
INSERT INTO t2 (id, t1_id, price) VALUES (7, 3, 500);
このようなテーブル構造で、
t2テーブルの同じt1_idの次のpriceから前のpriceを引いた値が全て正
のt1_idを抽出したいのですが、どのようなSQL文にすれば良いのでしょうか?
例えば、
t1が1のidだと
50-10=40で正なのでまずはOK
30-50=-20で負なのでNG
t1が2のidだと
3000-1000=2000で正なのでOK → 抽出へ
t1が3のidは
1つしかないのでNG
t1が4のidは
t2に行が存在しないのでNG
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
普通に応用してください
select t_1.*,t_3.id,t_3.price-t_1.price as diff from t2 as t_1
left join(
select *,(select count(*)+1 from t2 where t1_id=t_2.t1_id and id<t_2.id) as rank from t2 as t_2
) as t_3 on t_1.t1_id=t_3.t1_id and (select count(*)+1 from t2 where t1_id=t_1.t1_id and id<t_1.id)=t_3.rank-1
where t_3.price>t_1.price
ご回答ありがとうございます。
何度もすみません、たしかに
> where t_3.price>t_1.price
で各々の正の結果だけ抽出できたのですが、
そうするとt1テーブルのidが2の行だけを取得するという目的が達成できなくなります・・・
つまりt1テーブルのidが1の行も取得されてしまうのです。
ここからどのように応用すれば「t1テーブルのidが2」の行だけ
id t1_id price id diff
5 2 1000 6 2000
だけを取得できるのでしょうか?
No.2
- 回答日時:
たとえばこう
CREATE TABLE t2 (
id int(11) NOT NULL primary key,
t1_id INT,
price INT
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO t2 (id, t1_id, price) VALUES
(1, 1, 10),
(2, 1, 50),
(3, 1, 30),
(4, 1, 100),
(5, 2, 1000),
(6, 2, 3000),
(7, 3, 500);
select t_1.*,t_3.id,t_1.price-t_3.price as diff from t2 as t_1
left join(
select *,(select count(*)+1 from t2 where t1_id=t_2.t1_id and id<t_2.id) as rank from t2 as t_2
) as t_3 on t_1.t1_id=t_3.t1_id and (select count(*)+1 from t2 where t1_id=t_1.t1_id and id<t_1.id)=t_3.rank+1
ご回答ありがとうございます。
大変申し訳ございません、
yambejpさんのご回答で今気づいたのですが、
自分の中では
「この条件に合致するt1テーブルの行を取得したい」
と考えていたのですが、
>t1_idを抽出したいのですが
と伝えてしまって、せっかくご回答頂いたのですが、
自分が希望する結果と違うものになってしまいました・・・
例えばこの場合だと、合致するt1テーブルの行はidが2の行なので
その行を取得したいのです。
直した質問です。
条件に合致するt1テーブルの行を取得したい。
その条件とは、
t2テーブルの同じt1_idで
t2テーブルのid順にidの大きいpriceからidの小さいpriceを引いた値が
それぞれの区間で全て正の場合のt1テーブルの行を取得する。
例えば、
t1が1のidだと
50-10=40で正なのでまずはOK
30-50=-20で負なのでNG
t1が2のidだと
3000-1000=2000で正なのでOK → このt1_idに該当するt1テーブルのidが2の行を取得へ
t1が3のidは
1つしかないのでNG
t1が4のidは
t2に行が存在しないのでNG
お手数ではございますが、もう一度この条件で
ご回答いただけないでしょうか?
よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL 次の時間帯の勝率の合計を求めるSQL文 1 2023/07/04 17:12
- PHP php エラー 2 2022/10/23 16:43
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- PHP PHP MySQLに画像を直接保存 2 2022/06/05 11:50
- MySQL MYSQL エラー 2 2022/10/18 11:37
- MySQL php テーブルを作れない 2 2022/11/17 18:22
- PHP php テーブルが作成できない 1 2022/11/17 23:41
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
[MySQL] 3つのテーブルの結合で...
-
エクセルの関数について教えて...
-
sqlで、600行あるテーブルを100...
-
SQLサーバから、項目の属性(型...
-
上位3位を求めるSQL文は?
-
副問合せの書き方について
-
SQL Left Join で重複を排除す...
-
SQLにて特定の文字を除いた検索...
-
[MySQL] UNIQUE制約の値を更新...
-
Access パラメータクエリをcsv...
-
selectした大量データをinsert...
-
親と子供が複数のSQL取得方法
-
テーブルが5つの時の結合の仕...
-
書籍の内容はまともでしょうか?
-
クエリ表示と、ADOで抽出したレ...
-
【SQL文】Insert into文で文法...
-
VIEWの元のテーブルのindexって...
-
inner joinをすると数がおかし...
-
Mysqlでunionを使った検索速度...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
SQLサーバから、項目の属性(型...
-
副問合せの書き方について
-
VIEWの元のテーブルのindexって...
-
エクセルの関数について教えて...
-
SQLにて特定の文字を除いた検索...
-
マイクラPC版のコマンドで効率...
-
select文のwhere句に配列を入れ...
-
sqlで、600行あるテーブルを100...
-
ある条件の最大値+1を初番する...
-
inner joinをすると数がおかし...
-
Unionした最後にGROUP BYを追加...
-
期間の重複を調べるSQL文につい...
-
クエリ表示と、ADOで抽出したレ...
-
Access パラメータクエリをcsv...
-
PL/SQLの変数について
-
MySQLのDATE型カラム値がNULLの...
-
php+mysqlで複数選択削除について
-
上位3位を求めるSQL文は?
おすすめ情報
テーブルt1は
CREATE TABLE IF NOT EXISTS t1 (
id int(11) NOT NULL,
name VARCHAR(1),
PRIMARY KEY(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
でした。
訂正します。