乐趣区

Mysql进阶技巧2利用mysql生成唯一序号

在数据库分表或者程序自己需要唯一 id 的情况下,我们需要一个生成唯一 id 的方案。
可以编写一个综合时间和某些特征生成唯一 id 的程序,也可以考虑使用数据库里自增 id 的特性来实现这个需求,下面举个 mysql 的例子。
首先创建一个专门生成 id 的表,其中 id 字段是主键,replace_key 字段为唯一键。

CREATE TABLE `ticket` (`id` bigint(20) unsigned NOT NULL auto_increment,
    `replace_key` char(1) NOT NULL default '',
    PRIMARY KEY (`id`),
    UNIQUE KEY `replace_key` (`replace_key`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=10001;

每次需要生成 id 时,利用 replace into 语句生成新的记录将旧的记录替换掉,然后返回此 id 即可。

REPLACE INTO `ticket` (`replace_key`) VALUES ('a');
SELECT LAST_INSERT_ID();
退出移动版