PHP将数组存入到数据库中

以下四种方法: 
1.implode()和explode()方式 
2.print_r()和自定义函数方式 
3.serialize()和unserialize()方式 
4.json_encode()和json_decode()方式

 
  1. <?php

  2. //1.implode和explode方式

  3. //2.print_r和自定义函数方式

  4. //3.serialize和unserialize方式

  5. //4.json_encode和json_decode方式

  6. // 如果想运行该文件,需要建立数据库admin,和数据表test,或者修改代码

  7. // //---------------------------------------------------------------

  8. // CREATE TABLE `test` (

  9. // `id` int(10) unsigned NOT NULL AUTO_INCREMENT key,

  10. // `array` text,

  11. // ) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;

  12. //定义用print_r将数组存储到数据库中的类

  13.  
  14. header('content-type:text/html; charset=utf8');

  15. define("DB_HOST","localhost");

  16. define("DB_USER","root");

  17. define("DB_PWD","0227");

  18. define("DB_DBNAME","admin");

  19. define("DB_CHARSET","utf8");

  20. // 定义逆置print_r值的类

  21. class Trie {

  22. protected $dict = array();

  23. protected $buf = '';

  24. function set($word, $value='') {

  25. if(is_array($word)) foreach($word as $k=>$v) $this->set($k, $v);

  26. $p =& $this->dict;

  27. foreach(str_split($word) as $ch) {

  28. if(! isset($p[$ch])) $p[$ch] = array();

  29. $p =& $p[$ch];

  30. }

  31. $p['val'] = $value;

  32. return $this;

  33. }

  34. function parse($str) {

  35. $this->doc = $str;

  36. $this->len = strlen($str);

  37. $i = 0;

  38. while($i < $this->len) {

  39. $t = $this->find($this->dict, $i);

  40. if($t) {

  41. $i = $t;

  42. $this->buf = '';

  43. }else $this->buf .= $this->doc{$i++};

  44. }

  45. }

  46. protected function find(&$p, $i) {

  47. if($i >= $this->len) return $i;

  48. $t = 0;

  49. $n = $this->doc{$i};

  50. if( isset($p[$n]) ) $t = $this->find($p[$n], $i+1);

  51. if($t) return $t;

  52. if( isset($p['val']) ) {

  53. $ar = explode(',', $p['val']);

  54. call_user_func_array( array($this, array_shift($ar)), $ar );

  55. return $i;

  56. }

  57. return $t;

  58. }

  59. function __call($method, $param) {

  60. echo "****\n$this->buf 未定义方法:$method 参数:" . join(',', $param) . "<br />\n";

  61. }

  62. }

  63.  
  64.  
  65.  
  66. class App extends Trie {

  67. public $res = array();

  68. protected $stack = array();

  69. protected $keyname = '';

  70. protected $buf = '';

  71. function __construct() {

  72. $this->stack[] =& $this->res;

  73. }

  74. protected function group() {

  75. if(! $this->keyname) return;

  76. $cnt = count($this->stack) - 1;

  77. $this->stack[$cnt][$this->keyname] = array();

  78. $this->stack[] =& $this->stack[$cnt][$this->keyname];

  79. $this->keyname = '';

  80. }

  81. protected function brackets($c) {

  82. $cnt = count($this->stack) - 1;

  83. switch($c) {

  84. case ')':

  85. if($this->keyname) $this->stack[$cnt][$this->keyname] = trim($this->buf);

  86. $this->keyname = '';

  87. array_pop($this->stack);

  88. break;

  89. case '[':

  90. if($this->keyname) $this->stack[$cnt][$this->keyname] = trim($this->buf);

  91. break;

  92. case ']':

  93. $this->keyname = $this->buf;

  94. }

  95. $this->buf = '';

  96. }

  97. }

  98. //类结束

  99. //

  100. //

  101. //连接数据库

  102. function connect(){

  103. $link = @mysql_connect(DB_HOST,DB_USER,DB_PWD) or die("数据库连接失败ERR:".mysql_errno().":".mysql_error());

  104. mysql_select_db(DB_DBNAME) or die("打开数据库失败");//mysql_errno()即显示错误数量;mysql_error()即显示错误信息;

  105. $sql = 'set names '.DB_CHARSET;

  106. mysql_query($sql) or die ("设置字符集失败");

  107. return $link;

  108. }

  109. //插入数据库函数

  110.  
  111. function insert($table, $array){

  112. $keys = join(",",array_keys($array));

  113. $vals = "'".join("','",array_values($array))."'";

  114. $sql = "insert {$table}({$keys})values({$vals})";

  115.  
  116. mysql_query($sql);

  117. return mysql_insert_id();

  118. }

  119. //提取刚刚插入的数据

  120. function select($table){

  121. $sql = "select array from {$table} order by id desc";

  122. if($result = mysql_query($sql)){

  123. $values = mysql_fetch_assoc($result);

  124. $value = array_pop($values);

  125. }else{

  126. echo '提取失败';

  127. }

  128. return $value;

  129. }

  130.  
  •  
  1. //implode方式 一维数组可以,二维数组不可以,并且关联数组无效

  2. function plode($table,$arr){

  3. echo '<h3 style="color:red"><b>implode</b>方式<br/>原数组,未插入前:</h3>';

  4. var_dump($arr);

  5. $str = addslashes(implode(",", $arr));

  6. $insert = array('id'=>'','array'=>$str);

  7. if(insert($table,$insert)){

  8. echo "插入成功.<br/>";

  9. }else{

  10. echo "插入失败";

  11. exit;

  12. }

  13. $value = select($table);

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

  15.  
  16. var_dump($value);

  17. $explode = explode(",",$value);

  18. echo '<h3 style="color:red"><最终提取后处理的内容:></h3>';

  19. var_dump($explode);

  20.  
  21. }

  •  
  1. // serialize方式

  2. function serial($table,$arr){

  3. echo '<h3 style="color:red"><b>serialize</b>方式<br/>原数组,未插入前:</h3>';

  4. var_dump($arr);

  5.  
  6. $serialize = addslashes(serialize($arr));

  7. $insert = array('id'=>'','array'=>$serialize);

  8. insert($table,$insert);

  9. $value = select($table);

  10. echo '<h3 style="color:red"><方式插入数据库中的内容:></h3>';

  11. var_dump($value);

  12. $serialize = unserialize($value);

  13. echo '<h3 style="color:red"><最终提取后处理的内容:></h3>';

  14. var_dump($serialize);

  15. }

 

  1. //json方式

  2. function json($table,$arr){

  3. echo '<h3 style="color:red"><b>json_encode</b>方式<br/>原数组,未插入前:</h3>';

  4. var_dump($arr);

  5.  
  6. $enjson = addslashes(json_encode($arr));

  7. $insert = array('id'=>'','array'=>$enjson);

  8. insert($table,$insert);

  9. $value = select($table);

  10. echo '<h3 style="color:red"><方式插入数据库中的内容:></h3>';

  11. var_dump($value);

  12. $deunjson = json_decode($value,true);

  13. echo '<h3 style="color:red"><最终提取后处理的内容:></h3>';

  14. var_dump($deunjson);

  15. }

  16. // 执行函数

  17. //函数end

  18.  
  19.  
  20. ?>

  21. <form action="" method="get">

  22. <select name="kind">

  23. <option value="1">一维数组</option>

  24. <option value="2">二维数组</option>

  25.  
  26. </select>

  27. <select name="id">

  28. <option value="1">implode方式</option>

  29. <option value="2">print_r方式</option>

  30. <option value="3">serialize方式</option>

  31. <option value="4">json_encode方式</option>

  32.  
  33. </select>

  34. <input type="submit" value="提交" name="submit">

  35. </form>

  36. <?php

  37.  
  38. if(!empty($_GET['submit'])){

  39. $kind = $_GET['kind'];

  40. $id = $_GET['id'];

  41.  
  42.  
  43. }else{

  44. echo "请选择后按提交键";

  45. exit;

  46.  
  47. }

  48. connect();

  49. $ar1 =array('abcd'=>"sdfasdf",'bbb'=>'lxg','ccc'=>'bbbbbbbbb');//定义一个一维数组

  50. $ar2 = array('a'=>$ar1,'b'=>$ar1); //二维数组

  51. $table = "test";//使用的数据表

  52. if($kind=='1'){

  53. $arr = $ar1;

  54. }else{

  55. $arr = $ar2;

  56. }

  57. switch ($id) {

  58. case '1':

  59. # code...

  60. plode($table, $arr);

  61. break;

  62. case '2':

  63. printR($table,$arr);

  64. break;

  65. case '3':

  66. serial($table,$arr);

  67. break;

  68. case '4':

  69. json($table,$arr);

  70. break;

  71. default:

  72. break;

  73. }

  74.  
  75. ?>

  76.  

 

  1. // print_r方式

  2. function printR($table,$arr){

  3. echo '<h3 style="color:red"><b>print_r方式</b><br/>原数组,未插入前:></h3>';

  4. var_dump($arr);

  5.  
  6. $print = addslashes(print_r($arr, true));

  7. $insert = array('id'=>'','array'=>$print);

  8. insert($table,$insert);

  9. $value = select($table);

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

  13.  
  14. var_dump($value);

  15. $p = new App;

  16. $p->set('Array','group')

  17. ->set('[','brackets,[')

  18. ->set('] =>','brackets,]')

  19. ->set(')','brackets,)');

  20. $p->parse($value);

  21. echo '<h3 style="color:red"><最终提取后处理的内容:></h3>';

  22.  
  23. var_dump($p->res);

  24. }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值