0

我被困在一个场景中,我需要保存用户输入,比如......(在 1 中我得到了这些结果)

$string = "'a':'php,'b':'.Net' ...
'c'    'java'
'c'    'php'
'c'    'java'
'a'   'php'
'a'    'java' ";

现在我需要将所有这些值存储在数据库中(只有唯一的对)。

到目前为止,我尝试了什么,用“,”分解了 $string,并将所有内容存储在一个数组中,例如

$array["a"] = "php";...但这也会覆盖 a = java... //问题

我不需要检查数据库是否已经存在..这已经处理(所有转储的数据一次性获得一个唯一标识符)。

我需要做的就是获取唯一的对并转储到数据库中......意味着

a = php, a = java, b = .net, c = java, c=php

我能看到的唯一解决方案是......在爆炸后......检查数据库中的配对是否针对新的唯一标识......mysql_num_rows......如果不存在则转储否则不......

有什么简单的方法...??

4

2 回答 2

0

达到您的目的的最佳方法是创建多维数组

            <?php

        $string = "'a':'php','b':'.Net','c':'java','c':'php','c':'java','a':'php','a':'java'";
        $array = array();

        $temp_arr = explode(",", $string);

        foreach($temp_arr as $key=>$value)
        {
            list($tempkey,$tempValue) = explode(':', $value);
            $tempKey    = trim($tempkey,"'");
            $tempValue  = trim($tempValue,"'");
            $array[$tempKey][] = $tempValue; 
        }


        $array = array_map('array_unique',$array);

        echo "<pre>";
        print_r($array);

        ?>

输出将是

Array
(
[a] => Array
    (
        [0] => php
        [2] => java
    )

[b] => Array
    (
        [0] => .Net
    )

[c] => Array
    (
        [0] => java
        [1] => php
    )

)
于 2013-03-25T11:59:40.173 回答
-1
$string = "'a':'php,'b':'.Net','c':'java','c':'php','c':'java','a':'php','a':'java'";

$temp = array_map(function($item) {
    list($key, $value) = explode(':', $item);
    return array(str_replace("'", "", $key) => str_replace("'", "", $value));
}, explode(",", $string));

$results = array();

foreach($temp as $item) {
    $key = key($item);
    if(!isset($results[$key]) || !in_array($item[$key], $results[$key])) {
        $results[$key][] = $item[$key];
    }
}

print_r($results);

输出:

Array
(
    [a] => Array
    (
        [0] => php
        [1] => java
    )

    [b] => Array
    (
        [0] => .Net
    )

    [c] => Array
    (
        [0] => java
        [1] => php
    )

 )
于 2013-03-24T07:05:22.440 回答