例如,我有两个数据库:
客户表(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,然后编写第二个查询