MySQL分库分表后的主键策略:跨越分布式难题,保持全局唯一ID的智慧实践
-- 创建一个分库分表后用于全局生成唯一ID的表
CREATE TABLE `t_global_id` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`biz_type` int(10) NOT NULL COMMENT '业务类型',
`max_id` bigint(20) NOT NULL DEFAULT '1' COMMENT '当前最大ID',
`step` int(10) NOT NULL COMMENT '每次ID增长的步长',
PRIMARY KEY (`id`),
UNIQUE KEY `uq_biz_type` (`biz_type`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
-- 获取下一个ID的存储过程
DELIMITER $$
CREATE PROCEDURE `p_next_id`(IN biz_type_p INT, OUT next_id BIGINT)
BEGIN
DECLARE max_id BIGINT;
DECLARE step INT;
SET @max_id = 0;
SET @step = 0;
-- 查询并更新对应业务类型的最大ID
SELECT `max_id`, `step` INTO @max_id, @step FROM `t_global_id` WHERE `biz_type` = biz_type_p FOR UPDATE;
SET next_id = @max_id + @step;
UPDATE `t_global_id` SET `max_id` = next_id WHERE `biz_type` = biz_type_p AND `max_id` = @max_id;
END$$
DELIMITER ;
-- 示例:获取下一个ID
SET @next_id = 0;
CALL `p_next_id`(1, @next_id);
SELECT @next_id;
这个示例展示了如何在分库分表的环境中生成全局唯一的ID。它使用了一个全局表t_global_id
来记录每种业务类型的最大ID和步长,并提供了一个存储过程p_next_id
来安全地获取下一个ID。这里的关键点是使用了FOR UPDATE
来保证在并发情况下的数据一致性和唯一性。
评论已关闭