将一组数据保存到单个mysql字段的好方法是什么?
另外,当我在mysql表中查询该数组时,有什么好方法可以将其恢复为数组形式?
序列化和反序列化是答案吗?
发布于 2009-12-30 12:37:36
一般来说,是的,序列化和反序列化是可行的。
但是,如果您的数据很简单,保存为逗号分隔的字符串可能更适合存储空间。例如,如果您知道您的数组将只是一个数字列表,那么您应该使用内爆/爆炸。这就是1,2,3
和a:3:{i:0;i:1;i:1;i:2;i:2;i:3;}
之间的区别。
如果不是,则序列化和反序列化所有情况下的工作。
发布于 2009-12-30 14:20:32
只需使用序列化PHP函数:
<?php
$myArray = array('1', '2');
$seralizedArray = serialize($myArray);
?>
但是,如果您使用的是像这样的简单数组,那么您还不如使用implode和explode.Use一个空数组,而不是new。
发布于 2012-12-28 02:53:56
序列化/取消序列化用于在数据库中存储的数组
访问http://php.net/manual/en/function.serialize.php
来自PHP手册:
在页面上的"Return“下查看
返回一个字符串,该字符串包含可以存储在任何地方的值的字节流表示形式。
请注意,这是一个可能包含空字节的二进制字符串,因此需要进行存储和处理。例如,serialize()输出通常应该存储在数据库的BLOB字段中,而不是CHAR或文本字段中。
注意:如果要将html存储到blob中,请确保对其进行base64编码,否则可能会破坏序列化函数。
示例编码:
$YourSerializedData = base64_encode(serialize($theHTML));
$YourSerializedData
现在可以存储在blob中了。
从blob获取数据后,您需要base64_decode,然后反序列化示例解码:
$theHTML = unserialize(base64_decode($YourSerializedData));
https://stackoverflow.com/questions/1978438
复制相似问题