PHP序列化字符串格式

标签 php mysql wordpress serialization

在 MySQL(对于 wordpress)中,post_metadata 中有以下值:

a:1:{i:0;a:2:{s:5:"title";s:7:"Payment";s:19:"percentage_complete";s:1:"5";}}

我们这样做:

$value_percentage = array (
      0 => 
      array (
        'title' => 'Payment',
        'percentage_complete' => '15',
      ),
    );
$serializedData = serialize($value_percentage);
update_post_meta( $id, $field_percentage, $serializedData );

但是在数据库中有:

s:78:"a:1:{i:0;a:2:{s:5:"title";s:7:"Payment";s:19:"percentage_complete";s:2:"15";}}";

如何避免 s:78:"

我们还尝试了以下方法:

$value_percentage['percentage_complete'] = '15';

但是数据库中有s:78:"

最佳答案

您可以使用 maybe serializemaybe_unserialize存储和拉取数据的功能

也许反序列化

$string = 'a:1:{i:0;a:2:{s:5:"title";s:7:"Payment";s:19:"percentage_complete";s:1:"5";}}';
echo '<pre>', print_r(maybe_unserialize($string), 1), '</pre>';

输出是这样的,

Array (
    [0] => Array (
            [title] => Payment
            [percentage_complete] => 5
        )

)

也许序列化

$value_percentage = array (
      0 => 
      array (
        'title' => 'Payment',
        'percentage_complete' => '15',
      ),
);
echo '<pre>', print_r(maybe_serialize($value_percentage), 1), '</pre>';

输出是

a:1:{i:0;a:2:{s:5:"title";s:7:"Payment";s:19:"percentage_complete";s:2:"15 ";}}

关于PHP序列化字符串格式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33851051/

相关文章:

javascript - 在年历的json数据源中填充mysql数据

php - SQL显示同一行

mysql - mysql 5.7版本默认make lock table吗?

mysql - 改进单个结果行中的串联左连接查询

php - 如何在 woocommerce 中以编程方式插入产品类型

php - 在 wordpress 上一起使用 style.php 和 style.css

css - 如何在父 div 中居中子 div 并留有边距?

javascript - 在页面 php 中加载文章

php - Str_Replace 正在替换 php 语法

php - 面向对象的数据库连接