为了账号安全,请及时绑定邮箱和手机立即绑定

针对我这样的需求,该如何设置这个数据库的结构?

针对我这样的需求,该如何设置这个数据库的结构?

慕森卡 2023-04-17 14:14:27
最近在做一个测试回归的系统,Server这边需要在每个Test执行的时候为它保留相关的数据,待测试结束后,删掉这些数据。也就是这个数据只是临时的,一般一次测试用例大概就几分种,因此单挑数据的存在时间非常短。所以想要选用Redis做数据存储。之前没有使用Key-Value数据存储的经验,我这边简单构想的单挑数据结构如下:{    sessionId: 123454,    gloablData: {}, // 在全局维持的数据     testWins: [         { winId: 123, parentWinId: 123, stats: 'running', testResult: {}         }     ] }其中testWinds为测试用所有可能会出现的窗口(窗口其实为浏览器窗口,这个可以无视),然后会为每个窗口记录信息,然后每个窗口有自己的子测试结果testResult,是一个复杂数据(但是可以用JSON字符串来储存,因为Server对它的具体内容不关心,输出给需要的接口就行了),globalData也一样,server不关心,设置成JSON字符串但是查看Redis文档,发现Redis貌似无法构建这么复杂的数据结构。我这边的简单设置是这样的:对于每次测试:有一条储存globalData:session_id:globalData和多条储存testWin数据:session_id:testWind_id其中globalData由于我这边的Server不关心也不会做查询,因此只保存JSON字符串,testResult也一样,这样的话,貌似其实就两种类型:session_id:testWind_id: { winId: 123, parentWindId: 123, stat: 'running', testResult: JSONString }session_id:globalData: JSONString
查看完整描述

2 回答

?
斯蒂芬大帝

TA贡献1827条经验 获得超8个赞

存储和使用可以用对象封装。

针对你的情况,我会这么存。

Key : "session:123454:globalData" Value: hash 这里存属性hash. (hget, hset)
Key : "sesison:123454:testWins" Value: list 存储 test wins' ids
Key : "session:123454:testWins:win_id" Value: hash 这里存wins属性hash,也就是你json串的东西。

存储这样,使用还是要用对象封装起来


查看完整回答
反对 回复 2023-04-20
?
神不在的星期二

TA贡献1963条经验 获得超6个赞

换MongoDB吧。看样子你是需要基于文档的数据库。

查看完整回答
反对 回复 2023-04-20
  • 2 回答
  • 0 关注
  • 115 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信