- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
redis键值设计 浅谈redis数据库的键值设计 导读:就爱阅读网友为您分享以下“浅谈redis数据库的键值设计”的资讯,希望对您有所帮助,感谢您对92的支持! 浅谈redis数据库的键值设计丰富的数据结构使得redis的设计非常的有趣。不像关系型数据库那样,DEV和DBA需要深度沟通,review每行sql语句,也不像memcached那样,不需要DBA的参与。redis的DBA需要熟悉数据结构,并能了解使用场景。下面举一些常见适合kv数据库的例子来谈谈键值的设计,并与关系型数据库做一个对比,发现关系型的不足之处。用户登录系统记录用户登录信息的一个系统, 我们简化业务后只留下一张表。关系型数据库的设计mysqlgt; select * from login;+---------+----------------+-------------+---------------------+| user_id | name | login_times | last_login_time |+---------+----------------+-------------+---------------------+| 1 | ken thompson | 5 | 2011-01-01 00:00:00 || 2 | dennis ritchie | 1 | 2011-02-01 00:00:00 || 3 | Joe Armstrong | 2 | 2011-03-01 00:00:00 |+---------+----------------+-------------+---------------------+user_id表的主键,name表示用户名,login_times表示该用户的登录次数,每次用户登录后,login_times会自增,而last_login_time更新为当前时间。redis的设计关系型数据转化为KV数据库,我的方法如下:key 表名:主键值:列名value 列值一般使用冒号做分割符,这是不成文的规矩。比如在php-admin for redis系统里,就是默认以冒号分割,于是user:1 user:2等key会分成一组。于是以上的关系数据转化成kv数据后记录如下:Set login:1:login_times 5Set login:2:login_times 1Set login:3:login_times 2Set login:1:last_login_time 2011-1-1Set login:2:last_login_time 2011-2-1Set login:3:last_login_time 2011-3-1set login:1:name ”ken thompson“set login:2:name “dennis ritchie”set login:3:name ”Joe Armstrong“这样在已知主键的情况下,通过get、set就可以获得或者修改用户的登录次数和最后登录时间和姓名。一般用户是无法知道自己的id的,只知道自己的用户名,所以还必须有一个从name到id的映射关系,这里的设计与上面的有所不同。set quot;login:ken thompson:idquot; 1set quot;login:dennis ritchie:idquot; 2set quot;login: Joe Armstrong:idquot; 3这样每次用户登录的时候业务逻辑如下(python版),r是redis对象,name是已经获知的用户名。#获得用户的iduid = r.get(quot;login:%s:idquot; % name)#自增用户的登录次数ret = r.incr(quot;login:%s:login_timesquot; % uid)#更新该用户的最后登录时间ret = r.set(quot;login:%s:last_login_timequot; % uid, datetime.datetime.now())如果需求仅仅是已知id,更新或者获取某个用户的最后登录时间,登录次数,关系型和kv数据库无啥区别。一个通过btree pk,一个通过hash,效果都很好。假设有如下需求,查找最近登录的N个用户。开发人员
您可能关注的文档
- OMNet操作指导.doc
- opengl 3d实例源代码 opengl 3D迷宫 C++实现 源代码.doc
- oracle 10g rac 虚拟机Oracle_10g_RAC_安装_图文.doc
- oracle dg oracle dg全.doc
- NX8.0组.doc
- oracle基本语法 Oracle基本语法2.doc
- oral english Free Talk on Oral English口语杂谈.doc
- osgearth编译环境配置 osgEarth编译环境配置_图文.doc
- ogre 教程 ogre中级教程.doc
- outlook错误代码1025 Outlook常见错误代码.doc
- form e 格式word文档 留学巴黎eWord文档.doc
- 05.17--市消防支队拥政爱民工作总结汇报.doc
- 010 5715 3469 题目c373baaad1f34693daef3e98.doc
- rehl6 安装yum REHL LINUX 配置本地yum源的方法.doc
- qzzn四川 公共基础知识(四川事业单位考试指定教材QZZN版)_图文.doc
- rich chigga rich_图文.doc
- risk assessment WHO_Risk_Assessment_for_BTP_2nd_PC_10_Dec_2014.doc
- rsc advances Recent advances in the solar water heating systems A review_图文.doc
- RTTS(Y221)封隔器.doc
- rubric 纽约州教师标准----NYSUT_Rubric_WITH_ADDITIONS_图文.doc
最近下载
- 中外建筑史幻灯片.ppt VIP
- 河北高速公路集团有限公司招聘笔试题库2024.pdf
- 《景观规划设计》课件——乡村景观园林庭院设计.pptx VIP
- 风力发电设备加工项目投资计划书(参考).docx
- 人教版高中地理必修第一册第一章:宇宙中的地球大单元整体教学设计2024.docx
- 工程造价软件应用 课件 第2章 广联达BIM土建计量平台应用.pptx
- 特色校本教材——魔幻数学(一年级).docx VIP
- 2025一建《建筑工程管理与实务》考前6套模拟卷.docx VIP
- 工程勘察服务成本要素信息(2022版).pdf VIP
- 2024年秋季学期新人教版七年级上册英语课件 Unit 1 You and Me (第4课时) Section B 1a-1d.pptx VIP
文档评论(0)