PHP PDO lastinsertid的上一个函数

时间:2016-04-05 15:27:09

标签: php mysql pdo

我觉得我真的过于复杂了整个场景。希望有人可以提供帮助。

我有一个表单,可以将数据提交到两个表(itemsuploads)。表单数据转到items,附件转到uploads。基本上我希望两个表都有相应的itemId列。

我的两个函数create()uploadFile()都有效。但是,我不确定如何在名为$crud->create()的变量中使用$itemId的lastInsertId值 - 请参阅我的代码中的注释。

我的功能的缩减版本如下,包括评论。

class.crud.php

class crud {

private $db;

function __construct($DB_con) {
    $this->db = $DB_con;
}

public function create($inv, $ip, $make){
    $stmt = $this->db->prepare("INSERT INTO items (inv,ip,make) VALUES (:inv,:ip,:make");
    $stmt->bindparam(":inv", $inv);
    $stmt->bindparam(":ip", $ip);
    $stmt->bindparam(":make", $make);
    $stmt->execute();
    return true;
}

public function uploadFile($itemId, $inv, $file, $file_type, $file_size) {
    $stmt = $this->db->prepare("INSERT INTO uploads (itemId,inv,file,type,size) VALUES (:itemId,:inv,:file,:file_type,:file_size)");
    $stmt->bindParam(":itemId", $itemId); // inserts 777
    $stmt->bindParam(":inv", $inv);
    $stmt->bindparam(":file", $file);
    $stmt->bindparam(":file_type", $file_type);
    $stmt->bindparam(":file_size", $file_size);
    $stmt->execute();  
    return true;
}

}

添加-data.php

if (isset($_POST['btn-save'])) {
    $itemId = '777'; //this successfully inserts 777 into the uploads.itemId teble, but i'd like to insert the lastInsertId value of $crud->create()
    $inv = $_POST['inv'];
    $ip = $_POST['ip'];
    $make = $_POST['make'];
    $file = rand(1000, 100000) . "-" . $_FILES['file']['name'];
    $file_loc = $_FILES['file']['tmp_name'];
    $file_size = $_FILES['file']['size'];
    $file_type = $_FILES['file']['type'];
    $folder = "uploaded_files/";

    if ($crud->create($inv, $ip, $make)) {
        echo 'success';
    } else {
        echo 'error';;
    }

    if (move_uploaded_file($file_loc, $folder . $file)) {
            $crud->uploadFile($itemId, $inv, $file, $file_type, $file_size);
        }
}

<form method='post' enctype="multipart/form-data">
    <input type='text' name='inv'>
    <input type='text' name='ip'>
    <input type='text' name='make'>
    <input type='file' name='file'>
    <button type="submit" name="btn-save"></button>
</form>

我的两张桌子的结构如下;

项目 (itemId是主要,唯一和自动递增)

+--------+---------+-----------------+-------+
| itemId | inv     | ip              | make  |
+--------+---------+-----------------+-------+
| 1      | 1293876 | 123.123.123.123 | Dell  |
+--------+---------+-----------------+-------+
| 2      | 4563456 | 234.234.234.234 | Dell  |
+--------+---------+-----------------+-------+
| 3      | 7867657 | 345.345.345.345 | Apple |
+--------+---------+-----------------+-------+

项目 (upload_id为主要,唯一且自动递增)

+-----------+--------+-----+----------+------------+------+
| upload_id | itemId | inv | file     | type       | size |
+-----------+--------+-----+----------+------------+------+
| 56        | 777    | 123 | test.txt | text/plain | 266  |
+-----------+--------+-----+----------+------------+------+
| 57        | 777    | 123 | test.txt | text/plain | 266  |
+-----------+--------+-----+----------+------------+------+
| 58        | 777    | 123 | test.txt | text/plain | 266  |
+-----------+--------+-----+----------+------------+------+

请原谅凌乱的代码。我只是想让逻辑正确,然后我可以继续工作。

感谢任何建议。

1 个答案:

答案 0 :(得分:0)

所以在@ Maximus2012的帮助下,我能够解决这个问题。

我更改了create()函数以返回lastInsertId()代替真或假。然后,我将create()函数返回的值赋给变量,而不是使用静态值。

所以我的工作代码现在看起来像这样;

public function create($inv, $ip, $make){
    $stmt = $this->db->prepare("INSERT INTO items (inv,ip,make) VALUES (:inv,:ip,:make");
    $stmt->bindparam(":inv", $inv);
    $stmt->bindparam(":ip", $ip);
    $stmt->bindparam(":make", $make);
    $stmt->execute();
    return $this->db->lastInsertId();
}

然后在我的add-data.php页面中,我简单地将一个vcariable更改为以下内容;

$itemId = $crud->create($inv, $ip, $make);

解决。