如何获取id如果它';s还没有添加到数据库中?(mysql)


How to GET id if it's not added to database yet? (mysql)

例如,我有两个数据库:

客户表(id自动增加)

---------------------------------------
----- id ----- name ----- surname -----
----- 1  ----- BOB  ----- test1   -----
----- 2  ----- Jhon ----- test2   -----
----- 3  ----- Nick ----- test3   -----
---------------------------------------

和产品表(id不为空,必须手动添加)

---------------------------------------------
----- id ----- product ----- date       -----
----- 1  ----- orange  ----- 10/10/2014 -----
----- 2  ----- apple   ----- 12/10/2014 -----
----- 3  ----- melon   ----- 26/10/2014 -----
---------------------------------------------

*我有一张更复杂、更大的桌子。

问题是:

使用一个add.php文件,我想添加

名称=____姓氏=_____

在从添加名称和姓氏(来自表客户)的字段中获取id后,使用它使用相同的id添加产品和日期(到产品表)。

我了解如何将信息添加到多个表中:HERE

但是,如何将信息添加到表1中,并在使用table1中的ID后添加tables2,这是我感到困惑的地方。

要插入第一行,请像往常一样使用此查询。

INSERT INTO customer (name, surname) 
              VALUES ('Marie', 'Antoinette')

它将为您的连接设置LAST_INSERT_ID()值。然后使用这个包含LAST_INSERT_ID()的查询来插入下一行。

INSERT INTO product (customer_id, product, date)
             VALUES (LAST_INSERT_ID(), 'Cake', '1770-04-18')

这使您可以在不显式检索LAST_INSERT_ID的情况下执行第二次插入。但是,如果一个客户有多个product行,那么SQL中需要一些稍微不同的内容。

INSERT INTO customer (name, surname) 
              VALUES ('Marie', 'Antoinette');
SET @custid =: LAST_INSERT_ID();
INSERT INTO product (customer_id, product, date)
             VALUES (@custid, 'Cake', '1770-04-18')
INSERT INTO product (customer_id, product, date)
             VALUES (@custid, 'Guillotine', '1770-04-19')

这是一种很好的方法,因为它可以在繁忙的系统中正常工作,在繁忙的环境中,可能有多个数据库客户端正在插入客户。LAST_INSERT_ID()由MySQL逐连接维护。这也很好,因为您不必检索最后插入的id值,然后再将其发回。

使用mysql_insert_id();,它会为您提供上次查询的id

http://php.net/manual/en/function.mysql-insert-id.php

php.net 中的示例

<?php
$link = mysql_connect('localhost', 'mysql_user', 'mysql_password');
if (!$link) {
    die('Could not connect: ' . mysql_error());
}
mysql_select_db('mydb');
mysql_query("INSERT INTO mytable (product) values ('kossu')");
printf("Last inserted record has id %d'n", mysql_insert_id());
?>

所以基本上执行第一个查询,用mysql_insert_id()获取id,然后编写第二个查询