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

「简记往来」开发历程系列:数据结构——如何设计收礼和送礼的双向关系

一、普通记账 vs 礼账:数据模型的本质区别

普通记账App的数据模型非常简单:

记录(金额、分类、时间、备注)

统计时只需要按时间或分类汇总即可。

但礼账完全不同。礼账要回答的问题是:

  • “张三累计给了我多少钱?”
  • “我累计给张三多少钱?”
  • “我和张三之间的净额是多少?”

这需要的是双向关系数据模型

二、核心表结构

简记往来的数据库设计围绕两张核心表展开:

联系人表(contacts)

字段类型说明
idstring主键
book_idstring所属账本
namestring标准姓名
tagsarray标签(同事/朋友/亲戚)
created_attimestamp创建时间

记录表(records)

字段类型说明
idstring主键
book_idstring所属账本
contact_idstring关联的联系人ID
typeenumreceive(收礼)/ send(送礼)
amountnumber金额
datestring日期
notestring备注
created_bystring录入人
created_attimestamp创建时间

两张表通过contact_id关联。一个联系人可以有多个记录(收礼和送礼)。

三、双向关系的存储方式

关键问题是:如何用一张表存储“双向关系”?

答案是:用type字段区分方向。

  • type: 'receive'表示“张三给了我钱”
  • type: 'send'表示“我给了张三钱”

查询时,按contact_id聚合,分别统计receivesend的总金额,相减得到净额。

SELECTcontact_id,SUM(CASEWHENtype='receive'THENamountELSE0END)astotal_receive,SUM(CASEWHENtype='send'THENamountELSE0END)astotal_sendFROMrecordsWHEREbook_id=?GROUPBYcontact_id

这就是差额统计的底层逻辑。

四、索引优化方案

6.8万用户、62万笔记录,查询速度怎么保证?

核心索引:

-- 按账本+联系人查询记录CREATEINDEXidx_records_book_contactONrecords(book_id,contact_id)-- 按账本+日期查询CREATEINDEXidx_records_book_dateONrecords(book_id,date)-- 按账本+类型统计CREATEINDEXidx_records_book_typeONrecords(book_id,type)

实际测试中,最复杂的查询(按账本聚合所有联系人的收送礼统计)响应时间稳定在200ms以内。

五、扩展性考虑

这套数据模型还支持几个扩展场景:

  • 多账本:通过book_id隔离,每个账本独立
  • 多人协作:通过created_by记录录入人
  • 数据导出:直接导出contactsrecords的联表查询结果

设计数据模型时想清楚“要回答什么问题”,比一开始就追求“大而全”更重要。简记往来的数据模型从一开始就围绕“人与人的差额”这个核心问题设计,后续所有功能都是在此基础上扩展的,没有做过大的重构。

http://www.cnnetsun.cn/news/2987161.html

相关文章:

  • Qwen A3B:3B激活实现35B性能的MoE端侧AI架构
  • SMTP默认禁用原理与国内邮箱发信实战指南
  • 卡梅德生物技术快报|abcore 纳米抗体文库替代方案:单框架全合成文库工程化实操全参数
  • Java方法重载中null导致歧义调用的原理与解决方案
  • Webpack终极提速指南:5个高级技巧让构建速度提升300%
  • Wand-Enhancer终极指南:免费解锁Wand专业版功能与远程控制体验
  • Path of Building完整指南:3步掌握流放之路最强Build规划工具
  • Deepseek V4如何重构AI推理的存储与光模块需求
  • 深度解析TypeScript文档注释:TSDoc完全实战指南
  • 跨平台音乐播放器:用开源技术重新定义你的音乐世界
  • 智能体记忆演化安全评估:MemEvoBench基准框架解析与实践启示
  • 【无人机】基于球向量的粒子群优化SPSO算法在无人机路径规划中的实现附Matlab代码
  • Wand-Enhancer终极指南:如何免费解锁Wand专业版完整功能
  • Krita AI Diffusion:让数字艺术创作从“手工“到“智能“的进化之路
  • DeepSeek-V 3.2 DSA稀疏注意力工程落地全解析
  • 姿势搜索:用身体动作直接找图片的终极革命
  • 康懋达推出数字戒断手机 Callback 8020:无干扰体验,多种特色功能可选!
  • STM32单片机16*16汉字点阵广告牌75-3(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • Lovart为何不自研模型却成最火AI设计Agent
  • 招聘时间可视化神器:Boss Show Time浏览器插件终极指南
  • 如何构建可持续的英语学习系统:从被动到主动的转变
  • Redis Lua引擎UAF漏洞CVE-2025-49844深度剖析与复现实践
  • 3分钟零基础指南:用AI全自动生成短视频的终极解决方案
  • 如何让Windows 7和Vista系统重新拥抱现代Python?PythonVista项目全面解析
  • 3个实战挑战:从无名杀扩展开发到深度定制的进阶指南
  • [深度] 质量管理发展史:从手工检验到2026年数字化质量4.0的技术演进
  • 自适应信息流调制:让视觉语言模型学会动态聚焦与推理
  • 大模型公司业务分拆的财务与技术逻辑解析
  • Buck电路峰值电流控制+斜坡补偿+电压电流双环控制Simulink仿真(5000字详解报告+仿真)
  • Momentum-Firmware:Flipper Zero终极RGB背光控制完全指南