这是我将采购订单表单保存到数据库的代码。
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;]数组,并希望将整个数组存储在一列中。那我该怎么办? 现在我的数据保存如下:
您可以通过purchase_id看到三个产品。因此,我想将所有product_id,所有产品名称,所有数量,单位,unit_rate存储在一列中。简而言之,我想只向数据库插入一行。那么我应该对foreach循环做什么改变?
答案 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;
}