问题拆分数组以在另一个数组中使用

时间:2013-01-23 16:07:26

标签: php mysql variables for-loop

我有一些数据,我目前有硬编码,基本上我试图拆分数字,1端口并重新创建它

'INSERT INTO '.$tbl_name.'(PortNumber) VALUES (1),(2),(3),(4),(5),(6),(7),(8),(9),(10),(11),(12),(145),(146),(147),(148),(149),(150),(151),(152),(153),(154),(155),(156)';

等等。我认为我有一个很好的开始......

PHP

//post vars 
$port = 24; //(int)$_POST['ports'];
$super = 2; //(int)$_POST['super'];
$col = 12; //(int)$_POST['columns'];
$row = 2; //(int)$_POST['rows'];
//rest of vars
$halfPort=$port/2;//12
$colHalf = $col / $super;//6
$half=$colHalf-1;//5
$count=1;
$and=1;
$one=1;

echo "<h1>here goes nothen</h1><br><br>";
//sperate port
$finalArray = array();
for ($i = $port; $i >= 1; $i -= $colHalf) {
    $tempArray = array();
    for ($j = 0; $j < $colHalf; $j++) {
        $tempArray[] = $i - $j;
    }
    $tempArray[]= sort($tempArray);
    $finalArray[] = implode(",", $tempArray);
}
$finalArray = array_reverse($finalArray);
echo "<pre>" . print_r($finalArray, true) . "</pre>";

echo "<br><br>";
//sql for insert
$sqlinsert='
        INSERT INTO '.$tbl_name2.'
        (PortNumber) VALUES ';
 $start='(';
 $end=')';
//preset b
$b=0;
for($c = $port; $c >= 1; $c -= $colHalf) {
    $queryStart = array();
$queryStart[]=explode(',',$finalArray[$b]);
   echo "<pre>" ."start". print_r($queryStart, true) . "</pre>";
    for($s=0; $s<6; $s+=$and) {
        $queryEnd = array();
        $queryEnd[] = $start.$queryStart[$s].$end;
                echo "<pre>" ."end". print_r($queryEnd, true) . "</pre>";
    }
$b+=1;
}

要实时查看,请在此处插入:http://phptester.net/index.php?lang=en baisaclly它到达$queryEnd,一切都下山,任何想法?

2 个答案:

答案 0 :(得分:1)

我不太确定你想做什么,但如果你只想构建类似INSERT查询的东西,你可以做类似的事情:

$tbl_name = '?';
echo 'INSERT INTO '.$tbl_name.'(PortNumber) VALUES ('.implode('),(', array_merge(range(1,12),range(145,156))).')';

答案 1 :(得分:0)

我想我明白了。每次For循环运行时,您都要重新初始化$ queryEnd数组。将其移出For循环。 麦克