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

Posted Chris-Chang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP将数组存入数据库中的四种方式相关的知识,希望对你有一定的参考价值。

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

最近突然遇到了一个问题,如何用PHP将数组存入到数据库中,经过自己的多方查找和研究,总结了以下四种方法: 1.implode()和explode()方
2.print_r()和自定义函数方式
3.serialize()和unserialize()方式
4.json_encode()和json_decode()方式
<?php
	// 将数组存入数据库中的四种方式详见我的博客 http://blog.csdn.net/the_victory
	//1.implode和explode方式
	//2.print_r和自定义函数方式
	//3.serialize和unserialize方式
	//4.json_encode和json_decode方式
	// 如果想运行该文件,需要建立数据库admin,和数据表test,或者修改代码
	//   	//---------------------------------------------------------------
	//  CREATE TABLE `test` (
	//   `id` int(10) unsigned NOT NULL AUTO_INCREMENT key,
	//   `array` text,
	// ) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;
  	//定义用print_r将数组存储到数据库中的类

header('content-type:text/html; charset=utf8');
	define("DB_HOST","localhost");
	define("DB_USER","root");
	define("DB_PWD","0227");
	define("DB_DBNAME","admin");
	define("DB_CHARSET","utf8");
	// 定义逆置print_r值的类
class Trie 
  protected $dict = array();
  protected $buf = '';
  function set($word, $value='') 
    if(is_array($word)) foreach($word as $k=>$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) . "<br />\\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 '<h3 style="color:red"><b>implode</b>方式<br/>原数组,未插入前:</h3>';
		var_dump($arr);
		$str = addslashes(implode(",", $arr));
		$insert = array('id'=>'','array'=>$str);
		if(insert($table,$insert))
			echo "插入成功.<br/>";
		else
			echo "插入失败";
			exit;
		
		$value = select($table);
		echo '<h3 style="color:red"><插入的内容:></h3>';
		
		var_dump($value);
		$explode = explode(",",$value);
		echo '<h3 style="color:red"><最终提取后处理的内容:></h3>';
		var_dump($explode);

	

// print_r方式
	function printR($table,$arr)
		echo '<h3 style="color:red"><b>print_r方式</b><br/>原数组,未插入前:></h3>';
		var_dump($arr);

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

		echo '<h3 style="color:red"><插入的内容:></h3>';

		var_dump($value);
$p = new App;
$p->set('Array','group')
  ->set('[','brackets,[')
  ->set('] =>','brackets,]')
  ->set(')','brackets,)');
$p->parse($value);
		echo '<h3 style="color:red"><最终提取后处理的内容:></h3>';

var_dump($p->res);
	


// serialize方式
function serial($table,$arr)
		echo '<h3 style="color:red"><b>serialize</b>方式<br/>原数组,未插入前:</h3>';
		var_dump($arr);

		$serialize = addslashes(serialize($arr));
		$insert = array('id'=>'','array'=>$serialize);
		insert($table,$insert);
		$value = select($table);
		echo '<h3 style="color:red"><方式插入数据库中的内容:></h3>';
		var_dump($value);
		$serialize = unserialize($value);
		echo '<h3 style="color:red"><最终提取后处理的内容:></h3>';
		var_dump($serialize);

//json方式
function json($table,$arr)
		echo '<h3 style="color:red"><b>json_encode</b>方式<br/>原数组,未插入前:</h3>';
		var_dump($arr);

		$enjson = addslashes(json_encode($arr));
		$insert = array('id'=>'','array'=>$enjson);
		insert($table,$insert);
		$value = select($table);
		echo '<h3 style="color:red"><方式插入数据库中的内容:></h3>';
		var_dump($value);
		$deunjson = json_decode($value,true);
		echo '<h3 style="color:red"><最终提取后处理的内容:></h3>';
		var_dump($deunjson);

// 执行函数
 //函数end


?>
<form action="" method="get">
<select name="kind">
	<option value="1">一维数组</option>
	<option value="2">二维数组</option>

</select>
<select name="id">
	<option value="1">implode方式</option>
	<option value="2">print_r方式</option>
	<option value="3">serialize方式</option>
	<option value="4">json_encode方式</option>

</select>
<input type="submit" value="提交" name="submit">
</form>
<?php

if(!empty($_GET['submit']))
	$kind = $_GET['kind'];
	$id = $_GET['id'];


else
	echo "请选择后按提交键";
	exit;
	

 connect();
$ar1 =array('abcd'=>"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将数组存入数据库中的四种方式的主要内容,如果未能解决你的问题,请参考以下文章

PHP URL参数获取方式的四种例子

PHP从数组中删除元素的四种方法实例

php访问url的四种方式

记录-实现深拷贝的四种方式

PHP自动加载SPL的四种处理方式

call apply bind 的区别,this的四种绑定方式