这个MySQL tinyblob键的“长度”应该是多少?

时间:2011-07-16 21:21:01

标签: mysql indexing ipv6 unique-constraint

对于我正在创建的包含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_startip_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”。

这里发生了什么,我该如何解决?

1 个答案:

答案 0 :(得分:1)