Как вставить несколько динамических строк в базу данных

У меня есть динамическая таблица с несколькими строками, которую я создал с помощью php и jQuery. Здесь ссылка для просмотра таблицы.

Все работает отлично, за исключением случаев, когда я вставляю данные в базу данных, серийные номера не сохраняются последовательно. Мои запросы вставки следующие:

for($i = 0; $i < count($_POST['C_Objectives']); $i++)
{
    $sql = "INSERT INTO Appraisal_Objectives (Serial_Number,Objectives,Measures,Targets,subtotal,Corporate_Objective,Row_Number,ID) Values ('$formno','||<==','==','==','".$_POST['SubTotals'][$i]."','".$_POST['C_Objectives'][$i]."','".$_POST['SNo'][$i]."','$statement')";
    $stmt = sqlsrv_query($conn, $sql);
    if($stmt === false)
        die(print_r(sqlsrv_errors(), true));
    else
        echo " ";
}

for($i = 0; $i < count($_POST['Measures']); $i++)
{
    $sql = "INSERT INTO Appraisal_Objectives (Serial_Number,Objectives,Measures,Targets,Weightage,Row_Number,target_date,ID) VALUES ('$formno','".$_POST['Objectives'][$i]."','".$_POST['Measures'][$i]."','".$_POST['Achievement'][$i]."','".$_POST['Weightage_Target'][$i]."','".$_POST['SNo'][$i]."','".$_POST['Date_Target'][$i]."','$statement')"; 
    $stmt = sqlsrv_query($conn, $sql);
    if($stmt === false)
        die(print_r(sqlsrv_errors(), true));
    else
        echo " ";
}

Серийный номер сохраняется в столбце Row_Number, используя $_POST['SNo'][$i]. Можно ли сохранить обе динамические строки, используя 1 запрос вставки, чтобы последовательные номера сохранялись последовательно?

Это результат массива $_POST:

    [Row_Number] => Array
        (
            [0] => 1
            [1] => 2
        )

    [C_Objectives] => Array
        (
            [0] => A
            [1] => B
        )

    [Objectives] => Array
        (
            [0] => a1
            [1] => a4
            [2] => a7
            [3] => b1
        )

    [Measures] => Array
        (
            [0] => a2
            [1] => a5
            [2] => a8
            [3] => b2
        )

    [Achievement] => Array
        (
            [0] => a3
            [1] => a6
            [2] => a9
            [3] => b3
        )

    [Date_Target] => Array
        (
            [0] => 2016-09-09
            [1] => 2016-09-09
            [2] => 2016-09-09
            [3] => 2016-09-09
        )

    [Weightage_Target] => Array
        (
            [0] => 25
            [1] => 25
            [2] => 25
            [3] => 25
        )

    [SNo] => Array
        (
            [0] => 3
            [1] => 4
            [2] => 5
            [3] => 6
        )

    [SubTotals] => Array
        (
            [0] => 75
            [1] => 25
        )

    [GrandTotal] => 100
)

Я также попытался сделать автоматический инкремент столбца, но все же не сохраняет данные в том же порядке, что и в интерфейсе.

введите описание изображения здесь

введите описание изображения здесь

Ответ 1

У вашей вставки проблемы с производительностью. Пожалуйста, измените свой способ вставки в базу данных. Вы можете сделать все из них в одном запросе. Даже если у вас есть 20 циклов для первых "для" и 20 циклов для второго "для".

Отвечайте на то, что вы спросили

Если вы хотите вставить заказ $_POST ['SNo'], измените эту строку

for($i = 0; $i < count($_POST['C_Objectives']); $i++)

в

foreach($_POST['SNo'] as $i)

Если вам нужно несколько вставить сразу, просто сделайте следующее:

INSERT INTO Appraisal_Objectives (Serial_Number,Objectives,...)
VALUES (Value1,Value2,...), (Value1,Value2,...)

Это то, что вы ДОЛЖНЫ делать

В вашем коде вы сделали тот же запрос в 6 запросах. Это может быть даже больше, чем 6 с более длинными массивами $_POST ['Measures'] или $_POST ['C_Objectives']. Вам нужно поместить их в один запрос, и когда вам не нужно устанавливать значение, просто установите его в значение по умолчанию для столбца. например NULL

Что-то вроде этого:

//first we create $values array. it contains all values that you need to insert to the db
$values = array();
$j=0;

for($i = 0; $i < count($_POST['C_Objectives']); $i++){
    $values[$j]['Serial_Number'] = $formno;
    $values[$j]['Objectives'] = '||<==';
    //and fill others here
    //fill all cols that you wrote inside your query with the correct order
    $j++;
}

for($i = 0; $i < count($_POST['Measures']); $i++){
    $values[$j]['Serial_Number'] = $formno;
    $values[$j]['Objectives'] = $_POST['Objectives'][$i];
    //and fill others here
    //fill all cols that you wrote inside your query with the correct order
    $j++;
}

//now create (value1,value2,...),(value1,value2,...),...
$query = NULL;
foreach($values as $value){
    $tmp = NULL;
    foreach($value as $v){
        $tmp .= ($v=='')? 'NULL,' : "'$v',";
    }
    $tmp = rtrim($tmp,',');
    $query .= "($tmp),";
}
$query = rtrim($query,',');

//Now Insert
$sql = "INSERT INTO Appraisal_Objectives (Serial_Number,Objectives,...) VALUES $query";

В этом примере я просто покажу вам, как это сделать. помните, что вы должны проверить $v и подготовить его по типу столбца.

Очень важно о ваших кодах

Если это не ваш исходный код, нет проблем, но если это так, пожалуйста, измените способ использования $_POST внутри вашего запроса. Он имеет очень низкую безопасность. по крайней мере, вам необходимо проверить их перед использованием.

Ответ 2

Да, вы можете вставить один запрос вставки.

        $arrMeasuresInsData = array();
        for($i = 0; $i < count($_POST['C_Objectives']); $i++) {
          $sql = "INSERT INTO Appraisal_Objectives (Serial_Number, Objectives, Measures, Targets, subtotal, Corporate_Objective, Row_Number, ID, Weightagen, target_date) 
          Values ('$formno',
                    '||<==',
                    '==',
                    '==',
                    '".$_POST['SubTotals'][$i]."',
                    '".$_POST['C_Objectives'][$i]."',
                    '".$_POST['SNo'][$i]."',
                    '$statement',
                    '',
                    '')";

            if(!empty($_POST['Measures'][$i])) {
                $arrMeasuresInsData[$i] = $_POST['Measures'][$i];
                $sql .= ",('$formno',
                        '".$_POST['Objectives'][$i]."',
                        '".$_POST['Measures'][$i]."',
                        '".$_POST['Achievement'][$i]."',
                        '',
                        '',             
                        '".$_POST['SNo'][$i]."',
                        '".$_POST['Date_Target'][$i]."',                
                        '".$_POST['Weightage_Target'][$i]."',
                        '$statement',)";
            }

          $stmt = sqlsrv_query($conn, $sql);
          if($stmt === false)
          {
            die(print_r(sqlsrv_errors(), true));
          }
          else
          {
            echo " ";
          }
        }

        for($i = 0; $i < count($_POST['Measures']); $i++) {
            if(isset($arrMeasuresInsData[$i])) {
                continue;
            }
          $sql="INSERT INTO Appraisal_Objectives (Serial_Number,Objectives,Measures,Targets,Weightage,Row_Number,target_date,ID) 
                VALUES ('$formno',
                        '".$_POST['Objectives'][$i]."',
                        '".$_POST['Measures'][$i]."',
                        '".$_POST['Achievement'][$i]."',
                        '".$_POST['Weightage_Target'][$i]."',
                        '".$_POST['SNo'][$i]."',
                        '".$_POST['Date_Target'][$i]."',
                        '$statement')"; 
          $stmt = sqlsrv_query($conn, $sql);
          if($stmt === false)
          {
            die(print_r(sqlsrv_errors(), true));
          }
          else
          {
            echo " ";
          }       
       }

Ответ 3

Я думаю, что вы ошибочно получаете свой массив $_POST. Вы должны изменить форму ввода и получить входную информацию, как показано ниже:

[C_Objectives] => Array
    (
        [Row_Number] => Array
            (
                [title]         =>      'xxx',
                [0]             =>      Array
                    (
                        [0]     =>      Array
                            (
                                [SNo]           =>  2
                                [Objectives]    =>  a1,
                                [Measures]      =>  a2,
                                [Achievement]   =>  a3,
                                [Date_Target]   =>  2016-09-09,
                                [Weightage_Target]  =>  25
                            ),
                            (
                                [SNo]           =>  3
                                [Objectives]    =>  a1,
                                [Measures]      =>  a2,
                                [Achievement]   =>  a3,
                                [Date_Target]   =>  2016-09-09,
                                [Weightage_Target]  =>  25
                            ),
                            (
                                [SNo]           =>  4
                                [Objectives]    =>  a1,
                                [Measures]      =>  a2,
                                [Achievement]   =>  a3,
                                [Date_Target]   =>  2016-09-09,
                                [Weightage_Target]  =>  25
                            ),
                        [SubTotals] =>  75
                    )   
            )
    },
    (
        [Row_Number] => Array
            (
                [title]         =>      'xxx',
                [0]             =>      Array
                    (
                        [0]     =>      Array
                            (
                                [SNo]           =>  6
                                [Objectives]    =>  a1,
                                [Measures]      =>  a2,
                                [Achievement]   =>  a3,
                                [Date_Target]   =>  2016-09-09,
                                [Weightage_Target]  =>  25
                            ),
                        [SubTotals] =>  25
                    )   
            )
    )

Ниже приведен единственный пример, который вы должны понимать, как это сделать.

Как было бы сложно узнать, какое значение принадлежит какой строке, возможно, это значение будет определено как 2-е ниже в третьей строке.

Ответ 4

С текущим кодом будет как минимум два оператора INSERT, и больше, когда $_POST['Measures'] или $_POST['C_Objectives'] содержат большее количество элементов.

Вы можете вставить несколько записей в один оператор, а вместо использования оператора for использовать foreach, поэтому вам не нужно делать учетную запись в переменной итератора. Затем сохраните значения в массивах и используйте implode() для объединения наборов значений для каждой записи.

Проверьте, какие значения вставляются в какие столбцы - кажется, что в первом цикле вашего примера вы вставляете значение из $_POST['SNo'][$i] в поле ID...

$values = array();
foreach($_POST['C_Objectives'] as $index=>$value) {
    $rowValues = array();
    $rowValues[] = $_POST['SNo'][$index];   //Serial_Number
    array_push($rowValues,$formno,'||<==','==','==');   //, Objectives, Measures, Targets, subtotal
    $rowValues[] = $_POST['SubTotals'][$index]; //Corporate_Objective
    $rowValues[] = $value;  //Row_Number: $value == $_POST['C_Objectives'][$index];
    $values[] = "('".implode("', '",$rowValues )."')";
}

$fields = array('Objectives','Measures','Achievement','Weightage_Target','SNo','Date_Target');
foreach($_POST['Measures'] as $index=>$value) {
    $rowValues = array($formno);
    foreach($fields as $field) {
        $rowValues[] = $_POST[$field][$index];
    }
    $values[] = "('".implode("', '",$rowValues )."')";
}

$sql = "INSERT INTO Appraisal_Objectives (Serial_Number,Objectives,Measures,Targets,subtotal,Corporate_Objective,Row_Number,ID) VALUES ".implode(', ',$values);

$stmt = sqlsrv_query($conn, $sql);
if($stmt === false) {
    die(print_r(sqlsrv_errors(), true));
}
else {
    echo " ";
}

Ответ 5

что ты собираешься делать? Выполнение двух циклов - это различная вставка.....

Решение: 1. Вторая операция обновления. 2. Организуйте данные в базу данных сразу.