0

我有一些数据,我目前已经硬编码,基本上我正在尝试拆分数字,1-port 并将其重新创建为

'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,一切都在走下坡路,有什么想法吗?

4

2 回答 2

1

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

$tbl_name = '?';
echo 'INSERT INTO '.$tbl_name.'(PortNumber) VALUES ('.implode('),(', array_merge(range(1,12),range(145,156))).')';
于 2013-01-23T16:43:40.150 回答
0

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

于 2013-01-23T16:22:17.230 回答