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>
<?phpif(!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的强大之处,第一种方式无法将多维数组存入数据库中,第二种方式还要用自定义类,推荐使用第三种和第四种方式!

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

转载于:https://www.cnblogs.com/warmday/p/4474243.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/544931.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android开发:利用Activity的Dialog风格完成弹出框设计

转&#xff1a;http://www.linuxidc.com/Linux/2011-08/41933.htm 在我们使用Dialog时&#xff0c;如果需要用到很多自己设计的控件&#xff0c;虽然可以让弹出框显示出我们需要的界面&#xff0c;但却无法找到地方完成控制代码的编写&#xff0c;如何解决这个问题呢,我们可以将…

Java中实现定时任务的3种方法!

今天我们不用任何框架&#xff0c;用最朴素的 Java API 来实现定时任务&#xff0c;本文会介绍 3 种实现方案&#xff0c;我们一起来看...1、 sleep 这也是我们最常用的 sleep 休眠大法&#xff0c;不只是当作休眠用&#xff0c;我们还可以利用它很轻松的能实现一个简单的定时任…

回文子序列_计算回文子序列的总数

回文子序列Problem statement: 问题陈述&#xff1a; Given a string str, find total number of possible palindromic sub-sequences. A sub-sequence does not need to be consecutive, but for any xixj i<j must be valid in the parent string too. Like "icl&q…

Zookeeper 的 5 大核心知识点!

1 ZooKeeper简介ZooKeeper 是一个开源的分布式协调框架&#xff0c;它的定位是为分布式应用提供一致性服务&#xff0c;是整个大数据体系的管理员。ZooKeeper 会封装好复杂易出错的关键服务&#xff0c;将高效、稳定、易用的服务提供给用户使用。如果上面的官方言语你不太理解&…

【视频版】最新版Swagger 3升级指南和新功能体验!

作者 | 王磊来源 | Java中文社群&#xff08;ID&#xff1a;javacn666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;Swagger 3.0 发布已经有一段时间了&#xff0c;它于 2020.7 月 发布&#xff0c;但目前市面上使用的主流版本还是 Swagger 2…

各大厂面试高频的面试题新鲜出炉,你能答上几道?

关于生产环境如何配置线程数&#xff0c;还是要根据业务来进行区分&#xff0c;我们时常会听到什么IO密集型、CPU密集型任务...那么这里提一个问题&#xff1a;大家知道什么样的任务或者代码会被认定为IO/CPU密集&#xff1f;又是用什么样的标准来认定IO/CPU密集&#xff1f;如…

c/c++如何获取数组的长度

2019独角兽企业重金招聘Python工程师标准>>> C、C中没有提供 直接获取数组长度的函数&#xff0c;对于存放字符串的字符数组提供了一个strlen函数获取长度&#xff0c;那么对于其他类型的数组如何获取他们的长度呢&#xff1f;其中一种方法是使 用sizeof(array) / s…

【送给读者】全新苹果 AirPods,包邮送一套!

为回馈长期以来科创人读者对本栏目的关注支持&#xff0c;本周小编联合了计算机领域八位高质量原创号主一起为大家送出一套 全新苹果AirPods 2代。以下推荐的公号原创率都很高&#xff0c;均为个人IP号&#xff0c;有些小伙伴应该已经关注部分公号。本次抽奖采用第三方抽奖小程…

进程控制(kill)

为什么80%的码农都做不了架构师&#xff1f;>>> kill&#xff1a;终止进程&#xff08;或传送信号到某进程&#xff09; kill [options] [process_ids] kill命令可以发送信号给进程&#xff0c;可以终止&#xff08;terminate&#xff09;&#xff08;默认操作&a…

Swagger增强神器:Knife4j!用它轻松实现接口搜索、Word下载、接口过滤...

视频版内容&#xff1a;Swagger 是开发中最常用的框架之一了&#xff0c;但 Swagger 本身又有很多不完善的地方&#xff0c;比如&#xff0c;在众多的接口中查询某一个接口&#xff0c;又或者是把所有的接口导出成 Word 格式等&#xff0c;都无法在 Swagger 中实现。有人可能会…

7种可能会导致内存泄漏的场景!

虽然Java程序员不用像C/C程序员那样时刻关注内存的使用情况&#xff0c;JVM会帮我们处理好这些&#xff0c;但并不是说有了GC就可以高枕无忧&#xff0c;内存泄露相关的问题一般在测试的时候很难发现&#xff0c;一旦上线流量起来可能马上就是一个诡异的线上故障。1. 内存泄露的…

logstash 过虑nginx访问日志

标题是不是可以翻译成这样&#xff1a;logstash Filters nginx access log好了&#xff0c;进入正题&#xff0c;日志管理服务器我用ElasticSearchLogStashKibanaRedis先说下我的架构&#xff1a;远程NGINX采集日志数据到REDISlogstashelasticsearchkibana服务器至于怎么部署&a…

Spring中的重试功能!嗯,有点东西

来源&#xff1a;https://albenw.github.io/posts/69a9647f/概要Spring实现了一套重试机制&#xff0c;功能简单实用。Spring Retry是从Spring Batch独立出来的一个功能&#xff0c;已经广泛应用于Spring Batch,Spring Integration, Spring for Apache Hadoop等Spring项目。 本…

关于Shell的一些常用命令

2019独角兽企业重金招聘Python工程师标准>>> ls -lat 列出当前目录所有东东的东东 ls -lath 人看的大小 ls -F | grep "/$"只搞目录 ls -lR 包括子目录… ls --ignore filename -lt 忽略某个 which&#xff0c;在PATH变量指定的路径中&#xff0c;搜索看某…

用Netty撸一个心跳机制和断线重连!

来源&#xff1a;www.jianshu.com/p/1a28e48edd92心跳机制何为心跳所谓心跳, 即在 TCP 长连接中, 客户端和服务器之间定期发送的一种特殊的数据包, 通知对方自己还在线, 以确保 TCP 连接的有效性.注&#xff1a;心跳包还有另一个作用&#xff0c;经常被忽略&#xff0c;即&…

ThreadLocal线程范围内的共享变量

模拟ThreadLocal类实现&#xff1a;线程范围内的共享变量&#xff0c;每个线程只能访问他自己的&#xff0c;不能访问别的线程。 package com.ljq.test.thread;import java.util.HashMap; import java.util.Map; import java.util.Random;/*** 线程范围内的共享变量* * 三个模块…

Java中操作Excel的3种方法,太好用了!

一、介绍在平时的业务系统开发中&#xff0c;少不了需要用到导出、导入excel功能&#xff0c;今天我们就一起来总结一下&#xff0c;如果你正为此需求感到困惑&#xff0c;那么阅读完本文&#xff0c;你一定会有所收获&#xff01;二、poi大概在很久很久以前&#xff0c;微软的…

代理服务器Tengine的研究与测试

代理服务器Tengine的研究与测试一、Tengine介绍1.首先要知道什么Nginx1)Nginx&#xff08;发音同 engine x&#xff09;是一款轻量级的Web 服务器&#xff0f;反向代理服务器及电子邮件&#xff08;IMAP/POP3&#xff09;代理服务器&#xff0c;并在一个BSD-like 协议下发行。由…

不错!SpringBoot发布Jar包优化瘦身指南!

概要说明随着Spring Boot的流行&#xff0c;大家体验到只需构建输出一个jar文件&#xff0c;然后只需一个java -jar命令就能部署运行应用的爽快。常见一些单体应用随着项目规模的扩展单个jar文件的大小越来越大&#xff0c;动辄两三百MB。如果再引入微服务架构&#xff0c;动辄…

CountDownLatch:别浪,等人齐再团!

一入王者深似海&#xff0c;从此对象是路人。哈喽观众老爷们大家好&#xff0c;我是战神吕布字奉先&#xff0c;今天给大家来一部吕布的教学视频&#xff01;咳咳&#xff0c;不对。大家好&#xff0c;我是磊哥&#xff0c;今天给大家来一篇 CountDownLatch 的文章。在开始之前…