在 MySQL 中插入带有外键的值
使用关系数据库时,通常需要将值插入带有外键的表中。以下是如何处理两种特定情况:
案例 1:插入具有现有教师的学生
在这种情况下,您知道教师的姓名,并且需要从 TAB_TEACHER 表中检索他们的 ID。以下查询使用子查询来获取外键值:
<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>
案例 2:插入带有新教师的学生
对于这种情况,您需要插入新老师和新学生。这需要两个单独的 INSERT 语句:
<code class="sql">-- Insert the new teacher INSERT INTO TAB_TEACHER(name_teacher) VALUES ('John Smith') -- Get the new teacher's ID SET @id_teacher_fk = LAST_INSERT_ID() -- Insert the new student with the foreign key value INSERT INTO TAB_STUDENT(name_student, id_teacher_fk) VALUES ('Jane Doe', @id_teacher_fk)</code>
请注意,具体语法可能会因您的 MySQL 版本而异。详细内容请参考官方文档。
以上是如何在 MySQL 中插入带有外键的值?的详细内容。更多信息请关注PHP中文网其他相关文章!