序列化和反序列化会话数组

时间:2015-02-01 05:16:23

标签: php codeigniter serialization

这是我将采购订单表单保存到数据库的代码。

function save(&$purchase_data,$purchase_id)
    {
        $success=false;

        //Run these queries as a transaction, we want to make sure we do all or nothing
        $this->db->trans_start();

        if($purchase_data)
        {
            if (!$purchase_id or !$this->exists($purchase_id))
            {  
                //$purchase_data['purchase_id'] = $purchase_id = $purchase_data['purchase_id'];
                $success = $this->db->insert('purchase_order',$purchase_data);
                $post_array['cart']=$this->session->userdata('data');
                /*print_r($post_array);
                exit;*/
                $purchase_id=$this->db->insert_id();
                $i=0;
    foreach($post_array['cart'] as $item)
    {
        //echo "<pre>"; print_r($item); echo "</pre>";
        $query = $this->db->query("SELECT name FROM phppos_items WHERE item_id='".$item['product_id']."'");
        foreach ($query->result() as $row)
{
    $product_name=$row->name;

}
        $product_id=$item['product_id'];
        $quantity=$item['quantity'];
        $unit=$item['unit'];
        $unit_rate=$item['unit_rate'];
        $query = $this->db->query("insert into phppos_productdetails(product_id,product_name,quantity,unit,unit_rate,purchase_id) values ('$product_id','$product_name','$quantity','$unit','$unit_rate','$purchase_id')");

        $i++;
    }
            }
}

现在这段代码在productdetails表中插入多行,但我想序列化$ post_array [&#39; cart&#39;]数组,并希望将整个数组存储在一列中。那我该怎么办? 现在我的数据保存如下:image

您可以通过purchase_id看到三个产品。因此,我想将所有product_id,所有产品名称,所有数量,单位,unit_rate存储在一列中。简而言之,我想只向数据库插入一行。那么我应该对foreach循环做什么改变?

2 个答案:

答案 0 :(得分:1)

你可以用php serialize函数序列化数组或对象,它会返回一个字符串,你可以保存在你的表varchar或text type列中更好地创建文本类型列字符串可以长,如果数组很长,一个简单的例子

$val = serialize(array('test','test2',"test3",'test4'=>'1'));

or 

$val = serialize($post_array['cart']);

当您从表中获取列时,您可以反序列化它将为您提供数组的字符串

print_r(unserialize($val));

or 

$cart = print_r($row->column_name);

你可以像现在一样循环推车。

答案 1 :(得分:0)

这些功能(来自PHP Session helpers)可以帮助您:

function decode_session($data){
  $temp = $_SESSION;
  session_decode($data);
  $out = $_SESSION;
  $_SESSION = $temp;
  return $out;
}

function encode_session($data){
  $temp = $_SESSION;
  $_SESSION = $data;
  $out = session_encode();
  $_SESSION = $temp;
  return $out;
}