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

MySQL高阶2066-账户余额

目录

题目

准备数据

分析数据

总结


题目

请写出能够返回用户每次交易完成后的账户余额. 我们约定所有用户在进行交易前的账户余额都为0, 并且保证所有交易行为后的余额不为负数。

返回的结果请依次按照 账户(account_id), 日期( day ) 进行升序排序 .

准备数据

Create table If Not Exists Transactions (account_id int, day date, type ENUM('Deposit', 'Withdraw'), amount int)
    Truncate table Transactions
    insert into Transactions (account_id, day, type, amount) values ('1', '2021-11-07', 'Deposit', '2000')
    insert into Transactions (account_id, day, type, amount) values ('1', '2021-11-09', 'Withdraw', '1000')
    insert into Transactions (account_id, day, type, amount) values ('1', '2021-11-11', 'Deposit', '3000')
    insert into Transactions (account_id, day, type, amount) values ('2', '2021-12-07', 'Deposit', '7000')
    insert into Transactions (account_id, day, type, amount) values ('2', '2021-12-12', 'Withdraw', '7000')

分析数据

select
    account_id, day,
    sum(case when type = 'Deposit' then amount else -amount end) over (partition by account_id order by day) balance
from
    transactions
order by
    account_id,day;

总结

使用开窗函数sum()计算不同的交易类型


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

相关文章:

  • Web自动化:Cypress 测试框架概述
  • 代码随想录算法训练营第三十五天-动态规划-01背包(二维)
  • 在Linux上如何让ollama在GPU上运行模型
  • 电脑风扇声音大怎么办? 原因及解决方法
  • LARGE LANGUAGE MODELS ARE HUMAN-LEVEL PROMPT ENGINEERS
  • Java基础(一)
  • 本地部署开源在线PPT制作与演示应用PPTist并实现异地远程使用
  • 【python实操】python小程序之过七游戏以及单词单复数分类
  • Java - LeetCode面试经典150题(三)
  • 交换基础【计算机网络】
  • MySQL 5.7 数据库的备份与恢复
  • Java项目实战II基于Java+Spring Boot+MySQL的美容院管理系统设计与实现(源码+数据库+文档)
  • 在线css像素px到rem的转换器
  • 准备蓝桥杯和ACM:C++标准库头文件及其常用功能简介
  • 服务器使用frp做内网穿透详细教程,请码住
  • Js运算符(操作符)
  • Swoft2.0学习笔记
  • ESP32 Bluedroid 篇(1)—— ibeacon 广播
  • 软件设计——随手笔记
  • Pytest+selenium UI自动化测试实战实例
  • (8)mysql容器启动第一次无论输入密码与否均会报错处理
  • 检索增强生成(RAG)有什么好的优化方案?
  • 拦截器 Interceptor 详解
  • react中的ref三种形式
  • C# Windows EventHandler事件的使用
  • 足球青训俱乐部管理:Spring Boot技术驱动