Welcome to the website navigation,本站只接受合法正规的企业网站,欢迎站长们提交你的网站获得展示和流量有任何问题请联系站长,欢迎大家加入本站。

                
提交网站
  • 网站:76083
  • 待审:5
  • APP:577
  • 文章:304416
  • 会员:56004
文字内链包年1000元 文字内链包年1000元 文字内链包年1000元 AI办公网站 AI绘画工具 AIchat

名站网址导航为大家免费提供关于网站编程方面的知识。

php将数组变成字符串implode和explodeK5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

  • 本篇文章的具体介绍如下请大家仔细看
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方式结果:K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

一维数组:K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

二维数组:报错K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

2.print_r方式K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

一维数组:K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

二维数组:K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

3.serialize方式:K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

一维数组:K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

二维数组:K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

4.json方式K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

一维数组:K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

二维数组:K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


 K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

以上几种方法从插入数据库的数据大小来看json方式最好,该演示中没有使用中文,如果将数组改成中文你会发现json的强大之处,第一种方式无法将多维数组存入数据库中,第二种方式还要用自定义类,推荐使用第三种和第四种方式!K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

自己毕竟能力有限,如果大家发现更多的方式和文章的不足之处,希望能指出,谢谢!K5zAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


关于网站编程方面的知识就说道这里了,希望能够对大家有作用。,PhP,将,数组,存入,数据库,中的,四种,方式,

分享到:

  admin

注册时间:

网站:0 个   APP:3 个  文章:0 篇

  • 76083

    网站

  • 577

    APP

  • 304416

    文章

  • 56004

    会员

赶快注册账号,推广您的网站吧!
文章分类
热门网站
最新入驻APP小程序

宝贝市场2023-02-08

宝贝市场——买手和卖家商品展示

夺宝助手2023-02-08

夺宝助手小程序,查看每日快夺宝平

查诚信2023-02-08

查诚信是一款免费的商业查询工具

车价天天报2023-02-08

快速连接汽车销售,获知汽车最新报

考勤助理小程序2023-02-08

上班签到考勤,实时定位,后台轻松

汽车报价大全查询2023-02-08

汽车报价大全查询提供最新汽车市