在 MySQL 中插入带有外键的值
使用关系数据库时,通常需要将值插入带有外键的表中。以下是处理两种具体情况的方法:
案例 1:插入具有现有教师的学生
在这种情况下,您知道教师的姓名,并且需要从 TAB_TEACHER 表中检索他们的 ID。以下查询使用子查询来获取外键值:
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
案例 2:插入带有新教师的学生
对于这种情况,您需要同时插入新教师和新学生。这需要两个单独的 INSERT 语句:
-- 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)
请注意,具体语法可能会因您的 MySQL 版本而异。具体可以参考官方文档。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3