PHP пока зациклить массив - PullRequest
0 голосов
/ 25 февраля 2019

После получения всех результатов из моей БД я добавил некоторые дополнительные данные ('Prio')

Я использовал метод $ _POST и сохранил следующий результат в массиве:

    array (size=4)
  'gereed' => string 'gereed' (length=6)
  1 => 
    array (size=7)
      'prio' => string '1' (length=1)
      'res' => string '456' (length=3)
      'base' => string '190203' (length=6)
      'lot' => string '101' (length=3)
      'split' => string '0' (length=1)
      'sub' => string '0' (length=1)
      'seq' => string '10' (length=2)
  2 => 
    array (size=7)
      'prio' => string '2' (length=1)
      'res' => string '456' (length=3)
      'base' => string '180676' (length=6)
      'lot' => string '10' (length=2)
      'split' => string '0' (length=1)
      'sub' => string '0' (length=1)
      'seq' => string '30' (length=2)
  3 => 
    array (size=7)
      'prio' => string '3' (length=1)
      'res' => string '456' (length=3)
      'base' => string '180676' (length=6)
      'lot' => string '10' (length=2)
      'split' => string '0' (length=1)
      'sub' => string '0' (length=1)
      'seq' => string '60' (length=2)

Теперь у меня есть только 3 строки, но может случиться так, что у меня будет 10 или более строк.

Я хочу отобразить эти данные так же, как в цикле while.Так что цикл пройдет по строкам (1, 2, 3, xx), и я могу просто показать их, например, как echo $row['prio'];

Может быть, это простой вопрос, но я все еще учусь.

РЕДАКТИРОВАТЬ!На входной части я получаю значение Prio.Я хочу обновить это значение в правой строке.

UPDATE VMSCHRIP_SIM SET OPERATION_PRIORITY = $_POST['prio'] WHERE BASE = $_POST['base'] AND RESOURCE = $_POST['res'] AND blablabla

что-то в этом роде ...

Вот часть моего кода.

if ($result > 1) {
        $i = 1;
        $stmt->execute();
        while ($row = $stmt->fetch(PDO::FETCH_ASSOC)){
            $TrCode = transactionCodeDirect($Employee, $row["WORKORDER_BASE_ID"], $row["WORKORDER_LOT_ID"], $row["WORKORDER_SPLIT_ID"], $row["WORKORDER_SUB_ID"], $row["SEQUENCE_NO"], $row["RESOURCE_ID"]);                  
            if ($TrCode <> ""){
                $actief = "<p class=text-success>Actief</p>";
            }else{
                $actief = "<p class=text-warning>Klaar om te starten</p>";
            }
            if($row["DESCRIPTION"] == ""){
                $description = strtok(wo_description($row["WORKORDER_BASE_ID"], $row["WORKORDER_LOT_ID"], $row["WORKORDER_SPLIT_ID"]), '(**');
            }else{
                $description = $row["PART_ID"]." : ".$row["DESCRIPTION"];
            }
            if($row["PREV_OP"] == "" and $row["MAT_REMAINING"] == '0'){
                $row["PREV_OP_COMPLETED_QTY"] = $row["CALC_END_QTY"];
            }
            ?>   
                <a href="#" class="list-group-item"> 
                    <div style="text-align:left">
                        <div class="row">
                            <div class="col-lg-1">  
                                <br>
                                <span class="fa-stack fa-1x">
                                    <i class="fa fa-circle-o fa-stack-2x"></i>
                                    <span  class="fa fa-stack-1x"><?php echo $row["OPERATION_PRIORITY"];?></span>
                                </span>
                            </div>
                            <div class="col-lg-1">  
                                <br>
                                    <input type="text" name="<?php echo $i; ?>[prio]" class="form-control" value="" autofocus placeholder="Prio">
                                    <input type="hidden" name="<?php echo $i; ?>[res]" value="<?php echo $row['RESOURCE_ID'];?>">
                                    <input type="hidden" name="<?php echo $i; ?>[base]" value="<?php echo $row['WORKORDER_BASE_ID'];?>">
                                    <input type="hidden" name="<?php echo $i; ?>[lot]" value="<?php echo $row['WORKORDER_LOT_ID'];?>">
                                    <input type="hidden" name="<?php echo $i; ?>[split]" value="<?php echo $row['WORKORDER_SPLIT_ID'];?>">
                                    <input type="hidden" name="<?php echo $i; ?>[sub]" value="<?php echo $row['WORKORDER_SUB_ID'];?>">
                                    <input type="hidden" name="<?php echo $i; ?>[seq]" value="<?php echo $row['SEQUENCE_NO'];?>">
                            </div>
                            <div class="col-lg-4">  
                                <b><?php echo $row["NAME"];?></b><br>
                                <?php echo $row["WORKORDER_BASE_ID"];?>/<?php echo $row["WORKORDER_LOT_ID"];?>.<?php echo $row["WORKORDER_SPLIT_ID"];?>-<?php echo $row["WORKORDER_SUB_ID"];?>:<?php echo $row["SEQUENCE_NO"];?><br>
                                Vorige bewerking: <?php echo $row["PREV_OP"];?><br>
                            </div>
                            <div class="col-lg-6">                          
                                <?php echo $description;?><br>                                  
                                <?php echo intval($row["COMPLETED_QTY"]);?> / <?php echo intval($row["CALC_END_QTY"]);?> (<?php echo intval($row["PREV_OP_COMPLETED_QTY"]);?>) Stuks
                                <div class="tooltip12"><i class="fa fa-question-circle"></i>
                                    <span class="tooltip12text">Aantal gereed / Totaal (Beschikbaar)</span>
                                </div><br>
                                Volgende bewerking: <?php echo $row["NEXT_OP"];?><br>
                            </div>
                            <div class="col-lg-1">
                                <?php if (transactionCodeDirect($Employee, $row["WORKORDER_BASE_ID"], $row["WORKORDER_LOT_ID"], $row["WORKORDER_SPLIT_ID"], $row["WORKORDER_SUB_ID"], $row["SEQUENCE_NO"], $row["RESOURCE_ID"]) <> ""){ ?>
                                    <i class="fa fa-rotate-right fa-4x" text-center"></i><br><b>Running</b>
                                <?php } ?>  
                            </div>                  
                        </div>
                    </div>
                </a>    
        <?php
        $i++;
        }
    }else{
        echo "Result is niet groter dan 1";
    }

Ответы [ 2 ]

0 голосов
/ 25 февраля 2019

Поскольку у вас есть двумерный массив, вы можете использовать функцию foreach в PHP для циклического перемещения по массиву.В приведенном ниже коде я использовал вложенную функцию foreach для зацикливания двумерного массива.

echo "<table><tr>th>Key</th><th>Value</th></tr>"; 
foreach($_POST['your_array'] as $value){
    if(is_array($value)){   
           foreach($value as $key => $val){
                echo "<tr>";
                echo "<td>" . $key . "</td>"; // prio
                echo "<td>" . $val . "</td>"; // 1
                echo "</tr>"
            }   

        }
    }
    echo "</table>";
0 голосов
/ 25 февраля 2019

Это может быть так.

foreach($_POST as $value){
    if(is_array($value)){
        foreach($value as $key => $val){
            // first iteration
            echo $key; // prio
            echo $val; // 1

            // in second iteration, `$val` contains '2'
        }   
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...