[英]from multi dimensional array to MySQL
我有一个名为$data
的多维数组,它基本上是从表中提取到数组中的数据。
这就是我使用 JS_extractor 获取数组的方式:
set_include_path(get_include_path() . PATH_SEPARATOR . './library/');
require_once 'JS/Extractor.php';
$extractor = new JS_Extractor(file_get_contents('temp.html'));
$body = $extractor->query("body")->item(0);
$table = $body->query("//table[@class='rstatisztika_tabla']")->item(0);
$data = array();
foreach ($table->query('tr') as $i => $tr) {
if ($i == 0) {
continue;
}
$a = $tr->query('.//a');
$a = $a->item($a->length - 1);
$url = $a->getAttribute('href');
$parsed = parse_url($url);
parse_str($parsed['query'], $query);
$data[] = array(
$a->textContent,
$url,
$query['user'],
);
}
//var_dump($data);
当我真正做
var_dump($data);
我明白了:
array(3)
{
[0]=> array(3)
{
[0]=> string(4) "Thad"
[1]=> string(7) "http://localhost/index.php?m=karakterlap&user=91"
[2]=> string(2) "91"
}
[1]=> array(3)
{
[0]=> string(4) "Bill"
[1]=> string(8) "http://localhost/index.php?m=karakterlap&user=110"
[2]=> string(3) "110"
}
[2]=> array(3)
{
[0]=> string(7) "Thadson"
[1]=> string(7) "http://localhost/index.php?m=karakterlap&user=147"
[2]=> string(3) "147"
}
}
我还有一个Mysql数据库表叫warlord
CREATE TABLE IF NOT EXISTS `warlord` (
`id` int(5) NOT NULL default '0',
`name` varchar(35) character set utf8 NOT NULL default '',
`active` tinyint(1) NOT NULL default '1',
UNIQUE KEY `id` (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
INSERT INTO `warlord` (`id`, `name`, `active`) VALUES
(2, 'Admin', 0), (100, 'Thadson', 1), (147, 'John', 1);
从数组中,我想将新用户 (Thad & Bill) 添加到军阀表并将它们设置为活动 (1)
我希望也在阵列中的用户 (Thadson) 保持活跃 (1)
但是我希望不在数组中的用户(John)设置为非活动(0)
并使不在阵列中(并且已经处于非活动状态)的管理员处于非活动状态 (0)
我知道这是一个非常初学者的问题,但我该怎么做?
谢谢
您可能希望使用 array_map 函数为多数组设置回调函数并对其进行相应处理:
我看到了这个,我试过了:
$data = array();
for($i=0; $i<count($data_array); $i++){
$data_items[$i] = explode(',', $data_array[$i]); // create a multi-dimensional array
$data[] = '( ' .$data_items[$i][2]. ', '.$data_items[$i][0]. ', '. 1 .')';
}
$sql = "INSERT INTO warlord(id, name, active) VALUES ('".$data_items[$i][2]."','".$data_items[$i][0]."','1') ";
...将数据放入我的表中
我忽略了数组中的第二个元素(看起来像这样的元素:[1]=> string(7) "user=91"),我尝试将元素 [2] 和 [0] 插入表中,并使新用户活跃,将 1 放入活跃字段。
这显然没有完成我需要的所有工作(实际上它没有做任何事情)而且我不知道我在做什么。 这就是我寻求帮助的原因。
如果我要解决这个问题,我会首先尝试将我的数组( $data
数组以及来自数据库的数组)组织成类似的格式(可能使用id
作为数组键),以便我可以使用array_intersect
工作找出$data
和$database
(即应该设置为 active 的人)和array_diff
来计算$data
的人而不是$database
的人(即需要添加到数据库中的人),然后array_diff
再次(这次首先使用$database
)来计算$database
而不是$data
的人(即应该设置为非活动的人)。
希望这有助于让您走上写作之路。 抱歉,我没有时间为您实际编写代码。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.