gpt4 book ai didi

php - 将大整数从 php 存储到 mysql 的最节省空间的方法?

转载 作者:行者123 更新时间:2023-11-29 06:50:27 25 4
gpt4 key购买 nike

我正在处理最长 128 位的整数。它们用于存储大量标志,我不需要对它们进行任何奇怪的数学运算,因此我可以将其视为 php 中的字符串以绕过 PHP_INT_MAX 限制。

我想将这些数字存储在 mysql 的 BINARY 列中。该列将需要 4-16 个字节来保存数字。

我的理解是 php 中的 BINARY 列是一个二进制字符串,这是否意味着我不使用 a-z 作为字符集的一部分会浪费空间?我应该使用不同类型的色谱柱吗?我是否需要在 php 中进行 base_convert 才能充分利用字符集?

如何将 php 中 128 位整数的字符串表示最有效地存储到 php 中的 128 位列中?

此外,如果我存储的大约一半整数只需要 4 个字节,我是否最好使用 VARBINARY 列?

最佳答案

假设您将使用 128 位的全部范围,每个数字的可能性相同,您可以存储的最节省空间的是每个数字存储 128/8 = 16 个字符。

虽然这种二进制表示和 PHP 字符串之间的转换有点问题。要将二进制字符串解码为 base-16 数字,您可以使用 unpack:

$numberInHex = unpack("H*", $binaryData);

如果必须将输出与十进制数相互转换,则必须使用 gmp 或 bc。

更新:一个例子:

> create table binary_test ( int128 binary(16) );
> insert into binary_test set int128 = 0x11223344556677889900112233445566;
> select hex(int128) from binary_test;
+----------------------------------+
| hex(int128) |
+----------------------------------+
| 11223344556677889900112233445566 |
+----------------------------------+

除了 0x1122...,您还可以使用 unhex('1122..')。

关于php - 将大整数从 php 存储到 mysql 的最节省空间的方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15775983/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com