woshiwzb 2024-04-11 17:01 采纳率: 0%
浏览 3

用mysql创建多个表格,表格单独创建成功,同时创建则失败.

用mysql创建多个表格,表格单独创建成功,同时创建则失败.
虽然我用分号可以把前三个表创建成功,但是不能创建四五表。苦恼了一晚上了,救一下新人马楼吧!

CREATE TABLE Teacher(
TNo VARCHAR(5) PRIMARY KEY,
TN NVARCHAR(10),
Sex NCHAR(1),
Prof NVARCHAR(10),
Sal INT,
Comm INT,
Dept NVARCHAR(20)
)
CREATE TABLE Student(
SNo VARCHAR(5) PRIMARY KEY,
SN  NVARCHAR(10),
Sex NCHAR(1),
Age INT,
Dept NVARCHAR(20)
)

CREATE TABLE Course(
CNo VARCHAR(5)  PRIMARY KEY,
CN NVARCHAR(10) NOT NULL,
CT INT
)
CREATE TABLE SC(
SNo VARCHAR(5) NOT NULL CONSTRAINT Student_Fore FOREIGN KEY REFERENCES Student(SNo),
CNo VARCHAR(5) NOT NULL CONSTRAINT Course_Fore FOREIGN KEY REFERENCES Course(CNo),
Score INT CONSTRAINT SC_Chk CHECK(Score>=0 AND Score<=100),
PRIMARY KEY(SNo,CNo)
)
CREATE TABLE TC(
TNo VARCHAR(5) NOT NULL CONSTRAINT Teacher_Fore FOREIGN KEY REFERENCES Teacher (TNo),
CNo VARCHAR(5) NOT NULL CONSTRAINT Course_Fore FOREIGN KEY REFERENCES Course(CNo),
  PRIMARY KEY(TNo,CNo)
)

  • 写回答

5条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2024-04-11 17:01
    关注

    引自免费微信小程序:皆我百晓生

    在MySQL中,如果你想要一次性创建多个表,你需要将每个CREATE TABLE语句放在一个SQL批处理中,通过分隔符(通常是分号 ;)来分隔不同的语句。然而,你提供的SQL代码中,每个表都是单独的,因此它们会被视为独立的查询执行。这会导致你在尝试创建第四个表时收到错误,因为之前已经定义过的约束名称(如Course_Fore)会被重复使用。

    为了修复这个问题,你可以将所有的CREATE TABLE语句放入一个SQL字符串中,并使用分号分隔。这里是一个修改后的版本:

    CREATE TABLE Teacher (
        TNo VARCHAR(5) PRIMARY KEY,
        TN NVARCHAR(10),
        Sex NCHAR(1),
        Prof NVARCHAR(10),
        Sal INT,
        Comm INT,
        Dept NVARCHAR(20)
    );
    
    CREATE TABLE Student (
        SNo VARCHAR(5) PRIMARY KEY,
        SN NVARCHAR(10),
        Sex NCHAR(1),
        Age INT,
        Dept NVARCHAR(20)
    );
    
    CREATE TABLE Course (
        CNo VARCHAR(5) PRIMARY KEY,
        CN NVARCHAR(10) NOT NULL,
        CT INT
    );
    
    CREATE TABLE SC (
        SNo VARCHAR(5) NOT NULL,
        CNo VARCHAR(5) NOT NULL,
        Score INT CHECK(Score >= 0 AND Score <= 100),
        PRIMARY KEY(SNo, CNo),
        CONSTRAINT Student_Foreign FOREIGN KEY (SNo) REFERENCES Student(SNo),
        CONSTRAINT Course_Foreign FOREIGN KEY (CNo) REFERENCES Course(CNo)
    );
    
    CREATE TABLE TC (
        TNo VARCHAR(5) NOT NULL,
        CNo VARCHAR(5) NOT NULL,
        PRIMARY KEY(TNo, CNo),
        CONSTRAINT Teacher_Foreign FOREIGN KEY (TNo) REFERENCES Teacher(TNo),
        CONSTRAINT Course_Foreign FOREIGN KEY (CNo) REFERENCES Course(CNo)
    );
    

    在这个版本中,我已经为外键约束添加了唯一的名称(例如,将Course_Fore更改为Course_Foreign),这样在同一个SQL批处理中就可以正确地创建所有表了。确保在运行这个SQL时,你是在一个支持批处理的环境中,比如MySQL命令行工具、PHPMyAdmin或其他数据库管理工具。

    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 4月11日

悬赏问题

  • ¥15 求MCSCANX 帮助
  • ¥15 机器学习训练相关模型
  • ¥15 Todesk 远程写代码 anaconda jupyter python3
  • ¥15 我的R语言提示去除连锁不平衡时clump_data报错,图片以下所示,卡了好几天了,苦恼不知道如何解决,有人帮我看看怎么解决吗?
  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制