有关redis问题的疑问-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

有关redis问题的疑问

2016-02-27 18:08:33 1652 1

从RDBMS彻底的过渡到NoSQL,关键的是不是NoSQL中的Key设计咧? 比如原先的登录注册,RDBMS中可能是
`user_id, username, password
1 , user , xxxxxxxx
2 , user2 , xxxxxxxx`
过渡到Redis,可以这样
`users:user password
users:user2 password`
检测用户是否已经注册
`RDBMS:
select count(*) from table where username = 'user2'
Redis:
Get users:user2`
但是抛弃“关系”又怎么实现“关系”呢? 比如用户还有profile。 redis可以以users:username为key。然后存个对象进去。 但是怎么进行搜索呢?比如,我要获取所有注册时间在指定时间的一批用户。当然,可以按照users:username:profile_name挨个存,比如:
`users:user2:profile_photo /path/hash.jpg
users:user2:profile_regdate timestamp
users:user3:profile_regdate timestamp`
但是,会不会出现,删除某用户的时候,由于特殊原因导致删不干净的问题……比如user3的所有数据正在删除,然后异常了,导致profile_regdate没有删除。而且以后也检测不到了。
再者,好友关系。redis可以这么存:
`relation:uid:fuid timestamp
relation:fuid:uid timestamp`
假设需求:获取我的好友的所有除我以外的所有好友。
暂时就这么多……不知道表述是否清楚了。
关于redis的问题,我的理解正确否?

取消 提交回答
全部回答(1)
  • 落地花开啦
    2019-07-17 18:49:10

    首先如果你要用多个字段的话,就不要单个单个存字段,或者把一个对象序列化以后再存,这样跟memcache完全没区别。
    其次,你要弄清一个事实,我们用redis不是来完全代替关系数据库的,像你说的那个按用户名搜索用户完全不用放到redis里,不要为了使用redis而去用redis。
    用redis你可以做缓存,这样你只需要把主键作为key,你也可以利用它的索引特性来做列表
    多个字段你可以用hash对象存储
    HMSET user:1234 name "hello" password "123456" timestamp "12321321"
    把主键存到一个SET或者SORTED SET里
    SADD user_list 1234
    值得注意的是redis的SORT命令可以代替SQL解决很多查询,比如像上面这种哈希存储方式,如果我们要按timestamp排序并在一定范围内列出user来
    SORT user_list BY user:*->timestamp GET # LIMIT 0 10 DESC
    它等同于SQL语句
    SELECT * FROM user ORDER BY timestamp DESC LIMIT 0 10

    0 0
相关问答

37

回答

ISV接入钉钉详细示例以及代码(JAVA版本)  --服务窗代码部分放出

蛋蛋oo蛋蛋 2016-08-13 16:22:00 55388浏览量 回答数 37

20

回答

[@倚贤][¥20]学习Java后端的疑惑

小江同志 2018-10-24 16:11:21 132609浏览量 回答数 20

38

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 259930浏览量 回答数 38

23

回答

【精品问答合集】Redis热门问答

李博 bluemind 2019-05-29 16:36:15 127196浏览量 回答数 23

9

回答

HaoSQL,好用的SQL等数据库一键包发布!

梦丫头 2017-11-14 15:20:55 71148浏览量 回答数 9

30

回答

基础语言百问-Python

薯条酱 2017-05-17 18:01:13 65242浏览量 回答数 30

11

回答

【精品问答合集】MongoDB热门问答

李博 bluemind 2019-05-29 16:50:19 121395浏览量 回答数 11

15

回答

对象存储oss【问答合集】

我是管理员 2018-08-03 14:54:02 67825浏览量 回答数 15

80

回答

高性能本地SSD盘ECS正式商用啦!!(增加SSD申请地址和官方测试结果)

qilu 2014-12-01 17:15:26 52835浏览量 回答数 80

13

回答

【精品问答合集】Java热门问答

李博 bluemind 2019-05-29 16:00:45 125743浏览量 回答数 13
+关注
落地花开啦
喜欢技术,喜欢努力的人
0
文章
7824
问答
问答排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载