PHP将数组存入数据库中的四种方式

PHP将数组存入数据库中的四种方式

最近突然遇到了一个问题,如何用PHP将数组存入到数据库中,经过自己的多方查找和研究,总结了以下四种方法:
1.implode()和explode()方
2.print_r()和自定义函数方式
3.serialize()和unserialize()方式
4.json_encode()和json_decode()方式
$v) $this->set($k, $v);
    $p =& $this->dict;
    foreach(str_split($word) as $ch) {
        if(! isset($p[$ch])) $p[$ch] = array();
        $p =& $p[$ch];
    }
    $p['val'] = $value;
    return $this;
  }
  function parse($str) {
    $this->doc = $str;
    $this->len = strlen($str);
    $i = 0;
    while($i < $this->len) {
        $t = $this->find($this->dict, $i);
        if($t) {
            $i = $t;
            $this->buf = '';
        }else $this->buf .= $this->doc{$i++};
    }
  }
  protected function find(&$p, $i) {
    if($i >= $this->len) return $i;
    $t = 0;
    $n = $this->doc{$i};
    if( isset($p[$n]) ) $t = $this->find($p[$n], $i+1);
    if($t) return $t;
    if( isset($p['val']) ) {
        $ar = explode(',', $p['val']);
        call_user_func_array( array($this, array_shift($ar)), $ar );
        return $i;
    }
    return $t;
  }
  function __call($method, $param) {
    echo "****\n$this->buf 未定义方法:$method 参数:" . join(',', $param) . "
\n"; } } class App extends Trie { public $res = array(); protected $stack = array(); protected $keyname = ''; protected $buf = ''; function __construct() { $this->stack[] =& $this->res; } protected function group() { if(! $this->keyname) return; $cnt = count($this->stack) - 1; $this->stack[$cnt][$this->keyname] = array(); $this->stack[] =& $this->stack[$cnt][$this->keyname]; $this->keyname = ''; } protected function brackets($c) { $cnt = count($this->stack) - 1; switch($c) { case ')': if($this->keyname) $this->stack[$cnt][$this->keyname] = trim($this->buf); $this->keyname = ''; array_pop($this->stack); break; case '[': if($this->keyname) $this->stack[$cnt][$this->keyname] = trim($this->buf); break; case ']': $this->keyname = $this->buf; } $this->buf = ''; } } //类结束 // // //连接数据库 function connect(){ $link = @mysql_connect(DB_HOST,DB_USER,DB_PWD) or die("数据库连接失败ERR:".mysql_errno().":".mysql_error()); mysql_select_db(DB_DBNAME) or die("打开数据库失败");//mysql_errno()即显示错误数量;mysql_error()即显示错误信息; $sql = 'set names '.DB_CHARSET; mysql_query($sql) or die ("设置字符集失败"); return $link; } //插入数据库函数 function insert($table, $array){ $keys = join(",",array_keys($array)); $vals = "'".join("','",array_values($array))."'"; $sql = "insert {$table}({$keys})values({$vals})"; mysql_query($sql); return mysql_insert_id(); } //提取刚刚插入的数据 function select($table){ $sql = "select array from {$table} order by id desc"; if($result = mysql_query($sql)){ $values = mysql_fetch_assoc($result); $value = array_pop($values); }else{ echo '提取失败'; } return $value; } //implode方式 一维数组可以,二维数组不可以,并且关联数组无效 function plode($table,$arr){ echo '

implode方式
原数组,未插入前:

'; var_dump($arr); $str = addslashes(implode(",", $arr)); $insert = array('id'=>'','array'=>$str); if(insert($table,$insert)){ echo "插入成功.
"; }else{ echo "插入失败"; exit; } $value = select($table); echo '

<插入的内容:>

'; var_dump($value); $explode = explode(",",$value); echo '

<最终提取后处理的内容:>

'; var_dump($explode); } // print_r方式 function printR($table,$arr){ echo '

print_r方式
原数组,未插入前:>

'; var_dump($arr); $print = addslashes(print_r($arr, true)); $insert = array('id'=>'','array'=>$print); insert($table,$insert); $value = select($table); echo '

<插入的内容:>

'; var_dump($value); $p = new App; $p->set('Array','group') ->set('[','brackets,[') ->set('] =>','brackets,]') ->set(')','brackets,)'); $p->parse($value); echo '

<最终提取后处理的内容:>

'; var_dump($p->res); } // serialize方式 function serial($table,$arr){ echo '

serialize方式
原数组,未插入前:

'; var_dump($arr); $serialize = addslashes(serialize($arr)); $insert = array('id'=>'','array'=>$serialize); insert($table,$insert); $value = select($table); echo '

<方式插入数据库中的内容:>

'; var_dump($value); $serialize = unserialize($value); echo '

<最终提取后处理的内容:>

'; var_dump($serialize); } //json方式 function json($table,$arr){ echo '

json_encode方式
原数组,未插入前:

'; var_dump($arr); $enjson = addslashes(json_encode($arr)); $insert = array('id'=>'','array'=>$enjson); insert($table,$insert); $value = select($table); echo '

<方式插入数据库中的内容:>

'; var_dump($value); $deunjson = json_decode($value,true); echo '

<最终提取后处理的内容:>

'; var_dump($deunjson); } // 执行函数 //函数end ?>
"sdfasdf",'bbb'=>'lxg','ccc'=>'bbbbbbbbb');//定义一个一维数组 $ar2 = array('a'=>$ar1,'b'=>$ar1); //二维数组 $table = "test";//使用的数据表 if($kind=='1'){ $arr = $ar1; }else{ $arr = $ar2; } switch ($id) { case '1': # code... plode($table, $arr); break; case '2': printR($table,$arr); break; case '3': serial($table,$arr); break; case '4': json($table,$arr); break; default: break; } ?>

1.implode方式结果:

一维数组:

二维数组:报错

2.print_r方式

一维数组:

二维数组:


3.serialize方式:

一维数组:


二维数组:


4.json方式

一维数组:


二维数组:


以上几种方法从插入数据库的数据大小来看json方式最好,该演示中没有使用中文,如果将数组改成中文你会发现json的强大之处,第一种方式无法将多维数组存入数据库中,第二种方式还要用自定义类,推荐使用第三种和第四种方式!

自己毕竟能力有限,如果大家发现更多的方式和文章的不足之处,希望能指出,谢谢!

你可能感兴趣的:(php,mysql,php,存储,数据库)