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) . "
\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

?>

一维数组

二维数组

implode方式

print_r方式

serialize方式

json_encode方式

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;

}

?>

php 数组存入mysql_PHP将数组存入数据库中的四种方式相关推荐

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

    最近突然遇到了一个问题,如何用PHP将数组存入到数据库中,经过自己的多方查找和研究,总结了以下四种方法: 1.implode()和explode()方式 2.print_r()和自定义函数方式 3.s ...

  2. 批量插入数据库语句java_java相关:MyBatis批量插入数据到Oracle数据库中的两种方式(实例代码)...

    java相关:MyBatis批量插入数据到Oracle数据库中的两种方式(实例代码) 发布于 2020-7-22| 复制链接 本文通过实例代码给大家分享了MyBatis批量插入数据到Oracle数据库 ...

  3. 【美联储圣路易斯分行在其研究数据库中追踪四种数字货币价格】

    gbcax链交所 [美联储圣路易斯分行在其研究数据库中追踪四种数字货币价格] 据coindesk消息,美国联邦储备银行圣路易斯分行正在其研究数据库Federal Reserve Economic Da ...

  4. spark 持久化 mysql_Spark读取数据库(Mysql)的四种方式讲解

    目前 一.不指定查询条件 这个方式链接MySql的函数原型是: def jdbc(url: String, table: String, properties: Properties): DataFr ...

  5. apereo cas mysql_Apereo CAS 5.0.X 默认提供的数据库认证的四种方式

    Apereo CAS 5.0.X中为我们提供了四种基于JDBC的AuthenticationHandler的实现,在cas-server-support-jdbc子模块中,下面一一对他们进行介绍. Q ...

  6. Apereo CAS 5.0.X 默认提供的数据库认证的四种方式

    Apereo CAS 5.0.X中为我们提供了四种基于JDBC的AuthenticationHandler的实现,在cas-server-support-jdbc子模块中,下面一一对他们进行介绍. Q ...

  7. android 数据库 字节数组,java - 如何使用活动的android序列化字节数组并将其存储到数据库中? - 堆栈内存溢出...

    我有一个图像作为byte[] ,我需要将此图像保存在数据库中. 我为此使用Active Android库. 我知道db中用于此目的的数据类型应该是BLOB. 我知道byte[]不能直接存储,我知道它应 ...

  8. Raptor-初始化数组的四种方式

    初始化数组的四种方式 目录 1. 问题描述 2. 四种方式 1) 顺序赋值初始化 2) 循环输入初始化 3) 循环随机初始化 4) 以0初始化数组 3. 运行实例 1. 问题描述 在初学Raptor时 ...

  9. 数组对象去重的四种方式(强推最后一种!!!)

    哈喽哈喽,我又来了. 今天分享的是数组对象去重的方式,先看看数组对象的形式: let arrObj = [{ name: "小红", id: 1 },{ name: "小 ...

最新文章

  1. bootstrap的日期选择器 完整源码demo附效果图
  2. Navicat Mac 虚拟组和连接颜色的作用
  3. 使用pngquant来压缩png资源缩小apk
  4. 伦敦大学 机器人科学(研究型硕士) 项目介绍!干货满满!
  5. 怎么给web 服务器 传文件,web文件传到服务器
  6. python 多进程并发_python并发编程之多进程
  7. 9 PP配置-生产主数据-工作中心相关-定义工序控制码
  8. c++ STL模板(一)
  9. HTML将广告关闭的JS代码,原生js对联广告代码制作浮动固定层可关闭对联广告横幅...
  10. java 调用阿里云翻译
  11. Axure 安装教程
  12. 包子笔记 - 关于沉没成本
  13. 如何给国外老师写邮件
  14. HUNNU 11786 Sir Charles Antony Richard Hoare
  15. node+ npm + yarn 安装及上手
  16. 如何初始化一个指针数组
  17. 2023年五一数学建模竞赛ABC题思路资料汇总贴
  18. 青语易呼电销机器人源码独立部署搭建步骤
  19. 20230425-PAT甲级1169
  20. python3基础18

热门文章

  1. 2022-02-25
  2. Android用shareUserID实现多个Activity显示在同一界面
  3. 2020——网鼎杯 (青龙组)jocker
  4. 2020-12-6(从反汇编理解指针和引用的区别)
  5. android插上耳机仍用扬声器播放音频
  6. HDU2041超级楼梯
  7. Acwing第 25 场周赛【完结】
  8. 1022 Digital Library (30 分) 【难度: 中 / 知识点: 哈希表】
  9. Spring boot使用Bootstrap
  10. Freemarker条件判断