涉及外键关系的表在插入数据时需要特别考虑,以保证数据的完整性。让我们探讨一下如何在 MySQL 中处理两种情况下的插入:
如果您有要插入的学生记录及其所属的教师已经存在,您可以使用子查询根据教师姓名检索外键 (id_teacher):
<code class="sql">INSERT INTO TAB_STUDENT(name_student, id_teacher_fk) SELECT 'Joe The Student', id_teacher FROM TAB_TEACHER WHERE name_teacher = 'Professor Jack' LIMIT 1</code>
如果学生是数据库中尚不存在教师,您需要执行两次单独的插入操作:
<code class="sql">INSERT INTO TAB_TEACHER(name_teacher) VALUES ('Dr. Smith')</code>
<code class="sql">INSERT INTO TAB_STUDENT(name_student, id_teacher_fk) VALUES ('Mary The Student', LAST_INSERT_ID())</code>
以上是如何将数据插入到具有外键约束的MySQL表中?的详细内容。更多信息请关注PHP中文网其他相关文章!