【发布时间】:2016-04-13 12:11:28
【问题描述】:
我正在努力在我的 cPanel 服务器上的 phpMyAdmin 中的两个表之间建立外键关系——为了简单起见,我只称它们为“父”和“子”。在子表中,我有一个 parent_id 列,我想用父表中的 id 号填充该列。我已经遵循了一些关于这方面的教程,但它似乎不起作用 - 创建了新记录,但子表上的 parent_id 列仍然为 NULL。
我的 html 表单数据被传递给 PHP,PHP 在同一操作中将数据插入到两个单独的表中,父表和子表。父表和子表本质上是重复的,但将来我可能会添加额外的子表,因此需要外键关系 - 基本上是具有未连接本地表的主表。
在 phpMyAdmin 中,我将父表和子表的存储引擎都设置为 InnoDB。在子表中,我添加了一个 parent_id 列,将默认设置为 NULL,并允许为 NULL。然后我对该列进行索引,并将外键约束设置为“父”。“ID”。 phpMyAdmin 自动生成了一个约束名称“child_ibfk_1”。 ON DELETE 和 ON UPDATE 都设置为级联。
当我创建新记录时,两个表都正确填充,但子表中的 parent_id 列是 NULL 而不是父表的 ID。
谁能看到我在这里做错了什么?非常感谢。
编辑 - php 插入语句:
$sql = "INSERT INTO parent (date, time, latitude, longitude, accuracy, species, deadinjured, sex, age, name, contact_info, notes, source)
VALUES ('$date', '$time', '$latitude', '$longitude', '$accuracy', '$species', '$deadinjured', '$sex', '$age', '$name', '$contact_info', '$notes', 'source 1');";
$sql .= "INSERT INTO child (date, time, latitude, longitude, accuracy, species, deadinjured, sex, age, name, contact_info, notes)
VALUES ('$date', '$time', '$latitude', '$longitude', '$accuracy', '$species', '$deadinjured', '$sex', '$age', '$name', '$contact_info', '$notes');";
【问题讨论】:
-
When I create a new record, both tables are populated correctly-- 我们能看到您正在执行的确切查询吗? -
马上来 - 我会将它们编辑到我原来的问题中。
-
您必须在插入子表的
INSERT命令中显式提供父 ID。您可以使用 API 的相关功能在插入父记录后立即获取它的 ID:e.g.mysql_insert_id()、mysqli::$insert_id、PDO::lastInsertId等 -
是的,谢谢,这绝对是正确的答案。
标签: php mysql database phpmyadmin foreign-keys