在 MySQL 中存储 IPv6 地址:DECIMAL(39,0) 与 VARBINARY(16)
当面临存储 IPv6 的挑战时对于 MySQL 中的地址,开发人员通常会考虑两个选项:DECIMAL(39,0) 和 2*BIGINT。虽然两者各有优点,但出现了一种较以前的方法更具优势的新解决方案。
DECIMAL(39,0) 与 2*BIGINT
DECIMAL(39,0)的优点:
DECIMAL(39,0) 的缺点:
VARBINARY(16)
在最新版本的 MySQL 中,VARBINARY(16) 已成为存储 IPv6 地址的首选方法。与 DECIMAL(39,0) 和 2*BIGINT 相比,它具有多个优点:
转换函数
要在 IPv6 地址的二进制和十进制表示形式之间进行转换,您可以使用以下 PHP 函数:
结论
对于在 MySQL 中存储 IPv6 地址,VARBINARY(16) 因其空间效率、快速索引和不存在溢出问题而成为首选解决方案。虽然 DECIMAL(39,0) 和 2*BIGINT 曾经是流行的方法,但 VARBINARY(16) 现在提供了性能和功能的最佳平衡。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3