
1 lisonfan 2018-05-04 21:44:18 +08:00 字符串好一些吧 |
2 fengyj 2018-05-04 21:48:43 +08:00 via Android 觉得 64 位二进制好点,毕竟好约束。 |
3 dobelee 2018-05-04 21:50:17 +08:00 via Android 只是用作记录的话与 v4 一样字符串就 ok 了吧。毕竟存储成本是最低的。 |
4 samray 2018-05-04 21:50:26 +08:00 首先应该明确是什么数据库,如果是 postgresql, 已经内置了专门的数据类型来存储 IP 地址(ipv4 和 ipv6) https://www.postgresql.org/docs/9.1/static/datatype-net-types.html |
5 glues 2018-05-04 21:51:47 +08:00 PostgreSQL 直接有 Network Address Types |
6 yangqi 2018-05-04 21:52:36 +08:00 mysql 5.6 开始直接 inet6_aton() https://dev.mysql.com/doc/refman/5.6/en/miscellaneous-functions.html#function_inet6-aton |
7 EPr2hh6LADQWqRVH 2018-05-04 21:53:53 +08:00 看具体实现喽,一看地址里面 0 到底多不多,二看实现里面有没有压缩这些 0 的处理 |
8 moult 2018-05-04 22:05:59 +08:00 借楼问一下,如果要实现 IPv6 的归属地数据表,该怎么存储。 原来 IPv4 的话,存一个 begin 和 end,然后查询的时候 ip>=begin && ip<=end 即可。但是 IPv6 显然不行了。 |
10 zsj950618 2018-05-05 01:40:48 +08:00 没想到这个问题 3 年了,ipv6 还没普及。 |
12 rootx 2018-05-05 04:41:46 +08:00 via iPhone 没想到这个问题 5 年了,Livid 还没研究出来。 |
13 lianyue 2018-05-05 08:05:47 +08:00 via iPhone 存二进制 字符串 就好了 |
14 fyyz 2018-05-05 13:11:39 +08:00 via Android 就存字符串 |
15 kaneg 2018-05-05 15:40:31 +08:00 via iPhone 不管是存字符串还是数字型,都最好格式化成标准形式,以便于在日后使用过程中查找匹配可以应对各种输入形式 |
17 hanssx 2023-09-15 19:16:46 +08:00 压缩到最小存储空间,16 位字符,每个字符 8 位,16*8=128 ,正好可以哎,但是每个字符表示 8 位,就会有不可见字符,64 种不同可能,2 的 6 次方,每个字符 6 位,128/6 除以不了。如果按照 64 进制来,128 位,给它补位到能整除的话,132/6=22 ,用 22 位存,末尾补 132-128=4 个零。 |