让对话AI帮助你做程序架构设计,以及解决你的疑问

我想问下对话AI,本文采取的是chatgpt免费版

我问:

你说程序的设计,前后端分离的BS架构。比如工人基础档案1000条记录,工程项目基础档案10条记录,其他相关这两个基础档案的具体功能,比如打卡记录,宿舍记录,工人调动记录。我们的系统可以很方便的获取具体功能的数据库记录,但是本身数据库记录并没有基础档案,只有外键ID. 那我在前端显示的时候,我有两个方案:

  1. 后端提供一个接口,直接显示具体功能和相关档案的信息(使用数据库左连接等相关技术)

  2. 后端提供3个接口,在载入第1个具体功能的记录页面时,例如打卡记录。第一次显示打卡记录的第1页时,同时调用另外两个基础档案接口,把基础档案全部调用出来存放在前端变量里。当调用打卡记录的第二个页面,第三个页面,第n个页面,都只调用具体功能的记录,而基础档案记录直接从页面变量里获取,并循环匹配。

==

你认为,哪个方案更好?

我:

综合以上建议,好的架构,是方案2(架构2)比较好,对吗?如果这样,基于缺点,我想做个变化,即进入某功能的页面后,及其下面有多个子功能或页面,只要进入功能主页面或者子功能主页面都会重新调用基础档案备用,并提示数据不准确时可采取刷新动作。

综上所对话,我们的结论,其实在web2.0时代就提出了,就是ajax开始盛行的年代...

尽量减少对数据库服务的压力是一个良好的设计原则,尤其是在高并发或大数据量的系统中。通过优化数据缓存、减少不必要的查询、合理设计接口等方式,可以有效地提升系统的性能和用户体验。

改进方案正是基于这一思路,既保留了前端缓存带来的性能优势,又通过灵活的刷新机制确保数据的一致性。这样可以在减少数据库压力的同时,保持系统的高效运行。

没有高手,却有AI相伴的羔手...

相关推荐
慢半拍iii22 分钟前
从零搭建CNN:如何高效调用ops-nn算子库
人工智能·神经网络·ai·cnn·cann
空白诗2 小时前
CANN ops-nn 算子解读:AIGC 风格迁移中的 BatchNorm 与 InstanceNorm 实现
人工智能·ai
皮卡丘不断更2 小时前
告别“金鱼记忆”:SwiftBoot v0.1.5 如何给 AI 装上“永久项目大脑”?
人工智能·系统架构·ai编程
JMchen1233 小时前
AI编程与软件工程的学科融合:构建新一代智能驱动开发方法学
驱动开发·python·软件工程·ai编程
说实话起个名字真难啊3 小时前
用docker来安装openclaw
docker·ai·容器
金融RPA机器人丨实在智能4 小时前
Android Studio开发App项目进入AI深水区:实在智能Agent引领无代码交互革命
android·人工智能·ai·android studio
乂爻yiyao4 小时前
Vibe Coding 工程化实践
人工智能·ai
慢半拍iii5 小时前
ops-nn算子库深度解析:昇腾神经网络计算的基础
人工智能·深度学习·神经网络·ai·cann
Elastic 中国社区官方博客6 小时前
Elasticsearch:Workflows 介绍 - 9.3
大数据·数据库·人工智能·elasticsearch·ai·全文检索
组合缺一6 小时前
Solon AI (Java) v3.9 正式发布:全能 Skill 爆发,Agent 协作更专业!仍然支持 java8!
java·人工智能·ai·llm·agent·solon·mcp