pace_03 2021-10-18 00:28 采纳率: 69.2%
浏览 72
已结题

SQL Server 2019两个表之间的主外键问题

请帮我指出错误,谢谢!
我创建了一个C表,有Cno(课程号),Cname(课程名),Tname(教师姓名),均为主键
T表,有Tname(教师姓名),Tno(教师工号),Cname(课程名),Tno为主键,Tname和Cname为外键参照C表

--C表创建
CREATE TABLE C
(
    Cno INT ,
    Cname CHAR(10),
    Tname CHAR(10) NOT NULL,
    PRIMARY KEY(Cno,Tname,Cname)
);
--T表创建
CREATE TABLE T
(
    Tname CHAR(10) NOT NULL, 
    Tno INT,
    Cname CHAR(10),
    PRIMARY KEY (Tno),
    FOREIGN KEY(Tname) REFERENCES C(Tname),
    FOREIGN KEY(Cname) REFERENCES C(Cname)
);

T表创建报错

消息 1776,级别 16,状态 0,第 1 行
在被引用表 'C' 中没有与外键 'FK__T__Tname__49C3F6B7' 中的引用列列表匹配的主键或候选键。
消息 1750,级别 16,状态 1,第 1 行
无法创建约束或索引。请参阅前面的错误。

  • 写回答

2条回答 默认 最新

  • 来自深海墨鱼 2021-10-19 11:32
    关注

    问题:你的主键是 PRIMARY KEY(Cno,Tname,Cname) 三个字段组合的主键,联合主键的外键必须同时引用主键无法单个引用

    CREATE TABLE T
    (
    Tname CHAR(10) NOT NULL,
    Tno INT,
    Cname CHAR(10),
    Cno INT ,
    PRIMARY KEY (Tno),
    FOREIGN KEY(Cno,Tname,Cname) REFERENCES C(Cno,Tname,Cname)
    )

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

报告相同问题?

问题事件

  • 系统已结题 11月3日
  • 已采纳回答 10月26日
  • 修改了问题 10月18日
  • 修改了问题 10月18日
  • 展开全部

悬赏问题

  • ¥15 做了个的二极管反向饱和电流测量电路,但是测试达不到效果
  • ¥15 树莓派启动AP热点传入数据
  • ¥15 multisim中关于74ls192n和DSWPK开关的问题(相关搜索:计数器)
  • ¥15 在误装Windows server2019 后如何利用Windows.old恢复?
  • ¥20 代码实现状态连接包过滤防火墙的设计与实现
  • ¥15 vscode的红色箭头爆红和has no default export报错
  • ¥15 关于#sql#的问题:#情况描述 在用vs对项目进行调试时,出现找不到网络路径,然后查看SQL配置工具,发现SQL服务显示远程调用过程失败(相关搜索:防火墙)
  • ¥15 eNSP中基于默认路由及浮动路由的公司与分部互联和校园网综合项目
  • ¥15 主要进行描述泥浆在管路不同区段泥浆的密度不相同,泥浆的密度有高有低,此时管路的摩阻分布需要怎么计算,(标签-matlab)
  • ¥40 通过编制程序计算圆管内层流充分发展对流换热,参数如图5-4,以及公式5-16所示,要求用表5-6对程序计算准确性进行验证