分表时如何获取用户的唯一ID

分表时如何获取用户的唯一ID

一般地,用户数据量大的时候,我们会使用分表存储。比如一个平台有1亿用户,将这一亿个用户同时保存在一个表中,是不合适的。采用按帐号分表的方案,有一个问题,就是如何计算用户的唯一ID,如何按帐号来分表,可以参考(基于帐号的CRC32分表方案)。

方法一:

利用一个数据库表的自增主键来获取用户的唯一UID,这种方法比较简单,而且比较保险。唯一担心的是并发量大会导致锁表,导致用户注册性能下降。

一下使用mysql来做一个简单的例子:

CREATE TABLE `auto` (
  `ID` bigint(20) NOT NULL AUTO_INCREMENT,
  `UN` char(1) NOT NULL,
  PRIMARY KEY (`ID`),
  UNIQUE KEY `un_char` (`UN`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=1;
#建立唯一索引,当使用replace into的时候,保证数据库中有且仅有一条记录,避免数据库过大的问题
REPLACE INTO `auto`(`id`,`UN`) VALUES(NULL,'1');
SELECT LAST_INSERT_ID();


方法二:

使用Redis(推荐)

计数器,简单来说是一个自增长的数值,比如用户的投票数,网站的访问次数等等。通过redis字符串类型,可以实现一个简单的计数器,贴上伪代码!

return incr auto_number 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值