Redis key 设计技巧mysql
1: 把表名转换为key前缀 如, tag:sql
2: 第2段放置用于区分区key的字段--对应mysql中的主键的列名,如userid服务器
3: 第3段放置主键值,如2,3,4...., a , b ,c分布式
4: 第4段,写要存储的列名ide
用户表 user , 转换为key-value存储ui |
|||
useridspa |
username设计 |
passworde索引 |
emailci |
9 |
Lisi |
1111111 |
lisi@163.com |
set user:userid:9:username lisi
set user:userid:9:password 111111
set user:userid:9:email lisi@163.com
keys user:userid:9*
(分布式的时候能够同时hash到一个服务器)
然而,如何用用户名来查询?是这样?
因此,最好的办法是:冗余设计:
Set user:username:lisi:uid 9
(根据user:username:lisi:uid找到9,而后再根据9找到其余信息)
2 注意:
在关系型数据中,除主键外,还有可能其余列也步骤查询,
如上表中, username 也是极频繁查询的,每每这种列也是加了索引的.
转换到k-v数据中,则也要相应的生成一条按照该列为主的key-value
Set user:username:lisi:uid 9
这样,咱们能够根据username:lisi:uid ,查出userid=9,
再查user:9:password/email ...