当前位置: 首页 > article >正文

力扣-股票的资本损益

大家好,我是空空star,本篇带大家了解一道简单的力扣sql练习题。

文章目录

  • 前言
  • 一、题目:1393. 股票的资本损益
  • 二、解题
    • 1.正确示范①
      • 提交SQL
      • 运行结果
    • 2.正确示范②
      • 提交SQL
      • 运行结果
    • 3.正确示范③
      • 提交SQL
      • 运行结果
    • 4.正确示范④
      • 提交SQL
      • 运行结果
    • 5.其他
  • 总结


前言


一、题目:1393. 股票的资本损益

Stocks 表:

+---------------+---------+
| Column Name   | Type    |
+---------------+---------+
| stock_name    | varchar |
| operation     | enum    |
| operation_day | int     |
| price         | int     |
+---------------+---------+

(stock_name, day) 是这张表的主键
operation 列使用的是一种枚举类型,包括:(‘Sell’,‘Buy’)
此表的每一行代表了名为 stock_name 的某支股票在 operation_day 这一天的操作价格。
保证股票的每次’Sell’操作前,都有相应的’Buy’操作。

编写一个SQL查询来报告每支股票的资本损益。
股票的资本损益是一次或多次买卖股票后的全部收益或损失。
以任意顺序返回结果即可。
SQL查询结果的格式如下例所示:

Stocks 表:
+---------------+-----------+---------------+--------+
| stock_name    | operation | operation_day | price  |
+---------------+-----------+---------------+--------+
| Leetcode      | Buy       | 1             | 1000   |
| Corona Masks  | Buy       | 2             | 10     |
| Leetcode      | Sell      | 5             | 9000   |
| Handbags      | Buy       | 17            | 30000  |
| Corona Masks  | Sell      | 3             | 1010   |
| Corona Masks  | Buy       | 4             | 1000   |
| Corona Masks  | Sell      | 5             | 500    |
| Corona Masks  | Buy       | 6             | 1000   |
| Handbags      | Sell      | 29            | 7000   |
| Corona Masks  | Sell      | 10            | 10000  |
+---------------+-----------+---------------+--------+

Result 表:
+---------------+-------------------+
| stock_name    | capital_gain_loss |
+---------------+-------------------+
| Corona Masks  | 9500              |
| Leetcode      | 8000              |
| Handbags      | -23000            |
+---------------+-------------------+


Leetcode 股票在第一天以1000美元的价格买入,在第五天以9000美元的价格卖出。资本收益=9000-1000=8000美元。
Handbags 股票在第17天以30000美元的价格买入,在第29天以7000美元的价格卖出。资本损失=7000-30000=-23000美元。
Corona Masks 股票在第1天以10美元的价格买入,在第3天以1010美元的价格卖出。在第4天以1000美元的价格再次购买,在第5天以500美元的价格出售。最后,它在第6天以1000美元的价格被买走,在第10天以10000美元的价格被卖掉。资本损益是每次(’Buy’->‘Sell’)操作资本收益或损失的和=(1010-10)+(500-1000)+(10000-1000)=1000-500+9000=9500美元。

二、解题

1.正确示范①

提交SQL

select 
stock_name,
sum(case when operation='Sell' then price else 0 end )-
sum(case when operation='Buy' then price else 0 end ) capital_gain_loss
from Stocks
group by stock_name;

运行结果

2.正确示范②

提交SQL

select 
stock_name,
sum(case when operation='Sell' then price else -price end ) capital_gain_loss
from Stocks
group by stock_name;

运行结果

3.正确示范③

提交SQL

select 
stock_name,
sum(if(operation='Sell',price,-price)) capital_gain_loss
from Stocks
group by stock_name;

运行结果

4.正确示范④

提交SQL

select 
stock_name,
sum(if(operation='Sell',price,0))-sum(if(operation='Buy',price,0)) capital_gain_loss
from Stocks
group by stock_name;

运行结果

5.其他


总结

正确示范①思路:
group by stock_name
sum(case when operation='Sell' then price else 0 end )-
sum(case when operation='Buy' then price else 0 end ) capital_gain_loss
正确示范②思路:
group by stock_name
sum(case when operation='Sell' then price else -price end ) capital_gain_loss
正确示范③思路:
group by stock_name
sum(if(operation='Sell',price,-price)) capital_gain_loss
正确示范④思路:
group by stock_name
sum(if(operation='Sell',price,0))-sum(if(operation='Buy',price,0)) capital_gain_loss


http://www.kler.cn/a/342.html

相关文章:

  • 深入解析MySQL索引结构:从数组到B+树的演变与优化
  • LeetCode-最长回文子串(005)
  • 一种寻路的应用
  • node.js和js
  • 在交叉编译中,常见的ELF(elf)到底是什么意思?
  • 使 el-input 内部的内容紧贴左边
  • Linux磁盘和文件系统管理
  • 我一个普通程序员,光靠GitHub打赏就年入70万,
  • Matplotlib从入门到精通05-样式色彩秀芳华
  • 十大经典排序算法(上)
  • 30岁了,说几句大实话
  • 大数据核心技术是什么
  • Java代码是如何被CPU狂飙起来的?
  • 【2023-Pytorch-检测教程】手把手教你使用YOLOV5做电线绝缘子缺陷检测
  • 20230315整理
  • 宇宙最强-GPT-4 横空出世:最先进、更安全、更有用
  • 考研408 王道计算机考研 (初试/复试) 网课笔记总结
  • 史上最全最详细的Java架构师成长路径图,程序员必备
  • 01背包入门讲解
  • 程序员的逆向思维
  • AcWing算法基础课笔记 第一章 基础算法
  • 【数据结构】链表OJ(二)
  • 测试背锅侠?入职软件测试后大d佬给我丢了这个bug分类分析,至今受益匪浅......
  • 实现异步的8种方式,你知道几个?
  • 二叉树习题
  • 【蓝桥杯-筑基篇】常用API 运用(1)