首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >将PHP数组保存到MySQL?

将PHP数组保存到MySQL?
EN

Stack Overflow用户
提问于 2009-12-30 12:33:31
回答 12查看 187K关注 0票数 93

将一组数据保存到单个mysql字段的好方法是什么?

另外,当我在mysql表中查询该数组时,有什么好方法可以将其恢复为数组形式?

序列化和反序列化是答案吗?

EN

回答 12

Stack Overflow用户

发布于 2009-12-30 12:37:36

一般来说,是的,序列化和反序列化是可行的。

但是,如果您的数据很简单,保存为逗号分隔的字符串可能更适合存储空间。例如,如果您知道您的数组将只是一个数字列表,那么您应该使用内爆/爆炸。这就是1,2,3a:3:{i:0;i:1;i:1;i:2;i:2;i:3;}之间的区别。

如果不是,则序列化和反序列化所有情况下的工作。

票数 27
EN

Stack Overflow用户

发布于 2009-12-30 14:20:32

只需使用序列化PHP函数:

代码语言:javascript
复制
<?php
$myArray = array('1', '2');
$seralizedArray = serialize($myArray);
?>

但是,如果您使用的是像这样的简单数组,那么您还不如使用implode和explode.Use一个空数组,而不是new。

票数 11
EN

Stack Overflow用户

发布于 2012-12-28 02:53:56

序列化/取消序列化用于在数据库中存储的数组

访问http://php.net/manual/en/function.serialize.php

来自PHP手册:

在页面上的"Return“下查看

返回一个字符串,该字符串包含可以存储在任何地方的值的字节流表示形式。

请注意,这是一个可能包含空字节的二进制字符串,因此需要进行存储和处理。例如,serialize()输出通常应该存储在数据库的BLOB字段中,而不是CHAR或文本字段中。

注意:如果要将html存储到blob中,请确保对其进行base64编码,否则可能会破坏序列化函数。

示例编码:

代码语言:javascript
复制
$YourSerializedData = base64_encode(serialize($theHTML));

$YourSerializedData现在可以存储在blob中了。

从blob获取数据后,您需要base64_decode,然后反序列化示例解码:

代码语言:javascript
复制
$theHTML = unserialize(base64_decode($YourSerializedData));
票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1978438

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档