【问题标题】:How to insert multiple dynamic rows into the database如何将多个动态行插入数据库
【发布时间】:2017-01-13 18:22:37
【问题描述】:

我有一个使用 php 和 jQuery 创建的多行动态表。这里是the link to view the table

一切正常,除了当我将数据插入数据库时​​,序列号不按顺序保存。我的插入查询如下:

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
)

我也尝试过使列自动递增,但保存数据的顺序与在前端输入时的顺序不同。

【问题讨论】:

  • 因为$formno 用于序列号。所以总是会保存相同的值。
  • 序列号保存在Row_Number中为$_POST['SNo'][$i]
  • 使用连接创建一个插入查询并一次调用它。
  • @SR1092 显示echo "&lt;pre/&gt;";print_r($_POST);的值
  • 如果我理解正确,您应该修改表格以使序列号字段成为自动递增的数字。那么你在插入记录时不需要处理任何事情。另外还不清楚为什么需要在表中进行两次不同的插入?

标签: php sql-server


【解决方案1】:

您的插入存在性能问题。请更改插入数据库的方式。您可以在一个查询中完成所有这些操作。即使第一个“for”有 20 个循环,第二个“for”有 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[KEY] 并且它是数组。如果$query 为空,则不要插入数据库。

关于您的代码非常重要

如果这不是您的原始代码,则没有问题,但如果是,请更改您在查询中使用 $_POST 的方式。它的安全性非常低。至少您需要在使用前对其进行验证。

【讨论】:

  • 你能显示存储在$query中的完整语句吗?
  • @Asish 在 $sql 之前使用 php 的 error_logecho $query; 来查看。
  • 不,我的意思是如果您可以在答案中写下这一点。这段代码在别的项目里写出来看看就很难了。
【解决方案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 " ";
          }       
       }

【讨论】:

  • 这很棒,但有一个小问题。只输入count($_POST['C_Objectives']中存在的记录数
  • 我已根据您的要求编辑了我的答案,如果您有任何其他疑问,请检查并告诉我..
  • 现在它正在插入确切数量的行,但顺序不正确。请参阅问题中的屏幕截图。
  • 请给我您收到的确切数组,以便我可以很好地帮助您。
  • 我已将其复制到答案中。 :)
【解决方案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 到第 3 行。

【讨论】:

    【解决方案4】:

    使用当前代码,将至少有两个 INSERT 语句,当$_POST['Measures']$_POST['C_Objectives'] 包含更多元素时,会更多。

    您可以使用一个语句插入多条记录,而不是使用 for 语句,而是使用 foreach,这样您就不必在迭代器上进行记账多变的。然后将值存储在数组中,并使用implode() 组合每条记录的值集。

    检查哪些值被插入到哪些列中 - 在您的示例的第一个 for 循环中,您正在将来自 $_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. 将数据一次性整理到数据库中。

      【讨论】:

      • 你有什么建议?我应该怎么做?我可以为两个动态行插入 1 个吗?
      • 你在问什么@SR1092?插入您使用的查询不是一个好习惯。如果你想插入序列号。然后在每次执行 foreach 时按顺序递增 $fromn。
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2013-12-18
      • 2014-04-20
      • 1970-01-01
      • 2021-01-23
      • 1970-01-01
      • 2014-11-02
      相关资源
      最近更新 更多