![](https://cdn-ak-scissors.b.st-hatena.com/image/square/e381c47f5bcaf18d3670508a2c74626ed1d0662e/height=288;version=1;width=512/https%3A%2F%2Fgihyo.jp%2Fassets%2Fimages%2FICON%2F2009%2F431_sql_academy2.png)
エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
第2回 更新なんてこわくない! (4)同じテーブル内の別の行から値を計算する | gihyo.jp
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
第2回 更新なんてこわくない! (4)同じテーブル内の別の行から値を計算する | gihyo.jp
今度は既存の行に対する更新ではなく、新規に行を追加するので、INSERT SELECT構文を使うことはすぐにわ... 今度は既存の行に対する更新ではなく、新規に行を追加するので、INSERT SELECT構文を使うことはすぐにわかります。あとはtrend列の計算方法ですが、行間比較とくれば……そう、使う道具は相関サブクエリです(リスト9)。 リスト9 trend列を計算してINSERTする更新SQL INSERT INTO Stocks2 SELECT brand, sale_date, price, CASE SIGN(price - (SELECT price FROM Stocks S1 WHERE brand = Stocks.brand AND sale_date = (SELECT MAX(sale_date) FROM Stocks S2 WHERE brand = Stocks.brand AND sale_date < Stocks.sale_date))) WHEN -1 THEN