对于我正在创建的包含IP范围的表,我需要在MySQL记录中存储两个128位(16字节)的int值。由于MySQL只支持最多8字节的整数,我发现我需要使用二进制列(tinyblob),这一切都很好。
CREATE TABLE `ip_ranges` (
`ip_start` tinyblob NOT NULL,
`ip_end` tinyblob NOT NULL,
...
UNIQUE KEY `index_ip_ranges_on_ip_start_and_ip_end` (`ip_start`(16),`ip_end`(16))
);
我在这两列上的唯一索引遇到了麻烦。据我所知,IPv6的整数表示是128位(16字节)。因此,我将唯一键中ip_start
和ip_end
列的唯一索引设置为16个字节。不幸的是,当填充真实的IPv6数据时,我最终得到重复的密钥错误:
> INSERT INTO `ip_ranges` (`ip_end`, `ip_start`, ...) VALUES ("42540649945883696925221210589465935872", "42540649945883696943667954663175487487", ...);
Duplicate entry '42540649945883696925221210589465935872-4254064994588369694366795' for key 'index_ip_ranges_on_ip_start_and_ip_end'
上面“重复条目”行上显示的键值使其看起来像ip_end
值的一部分正在被删除。它丢失了最后13位数字:“4663175487487”。这让我觉得我错误地提到了代表字节的唯一密钥长度的“16”。
这里发生了什么,我该如何解决?
答案 0 :(得分:1)