日出259 2023-05-27 17:30 采纳率: 54.5%
浏览 37
已结题

mysql语句中外码约束导致插入失败的原因

最后一步插入失败

CREATE TABLE student(
sno INT PRIMARY KEY,
sname VARCHAR(20) NOT NULL,
sage INT DEFAULT 18
);

CREATE TABLE course(
cno INT PRIMARY KEY,
cname VARCHAR(20) NOT NULL,
ccredit INT DEFAULT 2
);

CREATE TABLE sc(
sno INT,
cno INT,
marks DECIMAL(4,1),
PRIMARY KEY(sno,cno),
FOREIGN KEY (sno) REFERENCES student(sno),
FOREIGN KEY (cno) REFERENCES course(cno)
);

ALTER TABLE sc MODIFY marks INT;
ALTER TABLE student
      ADD sgender CHAR(2),
      ADD sdept CHAR(20),
      ADD GPA DECIMAL(3,2);
ALTER TABLE course
      ADD cpre INT,
      ADD FOREIGN KEY(cpre) REFERENCES course(cno);
#为 student 表 在 sname 列上定义一个名为index_student_sname的普通索引;
CREATE INDEX index_student_sname ON student(sname);
#student 表使用四条 INSERT 语句插入四条数据;
INSERT INTO student(sno,sname,sgender,sage,sdept) VALUES (19111602,'王小珂','女',19,'信息系');
INSERT INTO student(sno,sname,sgender,sage,sdept) VALUES (19116103,'卞嘉欣','女',20,'信息系');
INSERT INTO student(sno,sname,sgender,sage,sdept) VALUES (19111604,'左眼陈','男',18,NULL);
INSERT INTO student(sno,sname,sgender,sage,sdept) VALUES (19111605,'田佳琪','女',19,'计算机系');


INSERT INTO course (cno,cname,ccredit) VALUES (1,'数据库原理',5),(2,'数学',4),(3,'操作系统',3),(4,'信息组织',4),(5,'C语言',3),(6,'数据结构',2);
UPDATE course
       SET cpre=6
       WHERE cno=1 OR cno=3;
UPDATE course
       SET cpre=1
       WHERE cno=4;
UPDATE course
       SET cpre=5
       WHERE cno=6;
UPDATE course
       SET cpre=NULL
       WHERE cno=2;
INSERT INTO sc (sno,cno,marks) VALUES (19116102,1,30),(19116102,3,87),(19116102,6,96),(19116102,1,69),(19116102,3,90);

```

  • 写回答

3条回答 默认 最新

  • Soulic 2023-05-27 18:05
    关注

    最后insert sc这个表,sno写错了(19116102),和insert student表中的sno不一样(19111602),因为创建了外键引用的是student表的数据,所以给的sno必须是student表中存在的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 6月4日
  • 已采纳回答 5月27日
  • 修改了问题 5月27日
  • 创建了问题 5月27日

悬赏问题

  • ¥15 系统 24h2 专业工作站版,浏览文件夹的图库,视频,图片之类的怎样删除?
  • ¥15 怎么把512还原为520格式
  • ¥15 MATLAB的动态模态分解出现错误,以CFX非定常模拟结果为快照
  • ¥15 求高通平台Softsim调试经验
  • ¥15 canal如何实现将mysql多张表(月表)采集入库到目标表中(一张表)?
  • ¥15 wpf ScrollViewer实现冻结左侧宽度w范围内的视图
  • ¥15 栅极驱动低侧烧毁MOSFET
  • ¥30 写segy数据时出错3
  • ¥100 linux下qt运行QCefView demo报错
  • ¥50 F1C100S下的红外解码IR_RX驱动问题