PDO从动态html表插入数据库值

时间:2015-02-03 18:56:51

标签: php mysql dynamic pdo

我是PHP的新手,并且一直在努力使用动态html表。我让表工作,我已经能够获取这些值并将它们插入到我的Mysql DB上的表中。但说实话,我很困惑为什么我的工作原理以及为什么我不能使用" bindValue"上班?

有人可以解释为什么bindValue方法不起作用?这是我的代码。如果你看到一些可以改进的东西,我会很高兴听到你的想法。

 <!-- This is from my HTML file -->

    <script language="javascript">

function addRow(tableID) { 

    var table = document.getElementById(tableID);

    var rowCount = table.rows.length;
    var row = table.insertRow(rowCount);

    var cell1 = row.insertCell(0);
    var element1 = document.createElement("input");
    element1.type = "checkbox";
    element1.name="chkbox[]";
    cell1.appendChild(element1);

    var cell2 = row.insertCell(1);
    cell2.innerHTML = "<input type='text' name='itemdesc[]' >";

    var cell3 = row.insertCell(2);
    cell3.innerHTML = "<input type='number'  name='unitprice[]' >";

    var cell4 = row.insertCell(3);
    cell4.innerHTML =  "<input type='number'  name='quantity[]' >";

    var cell4 = row.insertCell(4);
    cell4.innerHTML =  "<input type='number'  name='linetotal[]' >";
    }

function deleteRow(tableID) {
    try {
    var table = document.getElementById(tableID);
    var rowCount = table.rows.length;

    for(var i=0; i<rowCount; i++) {
        var row = table.rows[i];
        var chkbox = row.cells[0].childNodes[0];
        if(null != chkbox && true == chkbox.checked) {
            table.deleteRow(i);
            rowCount--;
            i--;
        }
    }
    }catch(e) {
        alert(e);
    }
}

这是来自我的.php文件

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


try
{
    $sql = "INSERT INTO invoicelineitem SET
        invoiceid = " . $last_id .",
        itemdesc = '" . $_POST['itemdesc'][$i] ."',
        unitprice = " . $_POST['unitprice'][$i].",
        quantity = " . $_POST['quantity'][$i].",
        linetotal = " . $_POST['linetotal'][$i];
    $s = $pdo->prepare($sql);
    $s->execute();

/* I can't get this to work

    $sql = 'INSERT INTO invoicelineitem SET
        invoiceid = :invoiceid,
        itemdesc = :itemdesc,
        unitprice = :unitprice,
        quantity = :quantity,
        linetotal = :linetotal';
    $s = $pdo->prepare($sql);
    $s->bindValue(':invoiceid', $last_id);
    $s->bindValue(':quantity', $_POST['quantity'][$i]);
    $s->bindValue(':untiprice', $_POST['unitprice'][$i]);
    $s->bindValue(':itemdesc', $_POST['itemdesc'][$i]);
    $s->bindValue(':linetotal', $_POST['linetotal'][$i]);
    $s->execute();
 */

这是我收到的错误消息:

  

例外&#39; PDOException&#39;消息&#39; SQLSTATE [HY093]:参数号无效:参数未定义&#39;在/media/sf_mcpi/mcpi/invoice/index.php:216堆栈跟踪:#0 /media/sf_mcpi/mcpi/invoice/index.php(216):PDOStatement-&gt; execute()#1 {main}

1 个答案:

答案 0 :(得分:1)

您的查询设置就好像是UPDATE查询一样。 INSERT查询不同,使用以下格式:

INSERT INTO `table` (`col1`, `col2`, ...)
VALUES ('val1', 'val2', ...)

INSERT要求您指定要插入的列,后跟相同数量的VALUES

更新:感谢@Mihai的好收获,“单位价格的不计价,占位符和bindparam值不同”