一、外键(了解)

外键(了解)

方式一:在创建表的时候,增加约束(麻烦,比较复杂)

DROP TABLE IF EXISTS `grade`;
CREATE TABLE IF NOT EXISTS `grade`(
  `gradeid` INT(5) NOT NULL ,
  `gradename` VARCHAR(20) NOT NULL,
  PRIMARY KEY(`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8;
-- 学生表的gradeid字段 要去引用年级表的 gradeid
-- 定义外键key
-- 给这个外键添加约束(执行引用) references 引用
DROP TABLE IF EXISTS `student`;
CREATE TABLE IF NOT EXISTS `student`(
  `id` INT(5) NOT NULL AUTO_INCREMENT COMMENT '学号',
  `name` VARCHAR(20) NOT NULL DEFAULT '大傻春' COMMENT '姓名',
  `pwd` VARCHAR(20)  NOT NULL DEFAULT '123456' COMMENT '密码',
  `sex` VARCHAR(2)  NOT NULL DEFAULT '男' COMMENT '性别',
  `birthday` DATETIME  NOT NULL DEFAULT '1997-7-10' COMMENT '生日',
  `address` VARCHAR(50)  NOT NULL DEFAULT '桂林' COMMENT '地址',
  `email` VARCHAR(30)  NOT NULL DEFAULT 'xxx@outlook.com' COMMENT '邮箱',
  `gradeid` INT(5) NOT NULL,
  PRIMARY KEY(`id`),
  KEY `FK_gradeid`(`gradeid`),
  CONSTRAINT `FK_gradeid` FOREIGN KEY(`gradeid`) REFERENCES `grade`(`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8;

删除有外键关系的表时,必须要先删除引用别人的表(从表),再删除被引用的表(主表)

方式二: 创建表成功后,添加外键约束

DROP TABLE IF EXISTS `grade`;
CREATE TABLE IF NOT EXISTS `grade`(
  `gradeid` INT(5) NOT NULL ,
  `gradename` VARCHAR(20) NOT NULL,
  PRIMARY KEY(`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8;
-- 学生表的gradeid字段 要去引用年级表的 gradeid
-- 定义外键key
-- 给这个外键添加约束(执行引用) references 引用
DROP TABLE IF EXISTS `student`;
CREATE TABLE IF NOT EXISTS `student`(
  `id` INT(5) NOT NULL AUTO_INCREMENT COMMENT '学号',
  `name` VARCHAR(20) NOT NULL DEFAULT '大傻春' COMMENT '姓名',
  `pwd` VARCHAR(20)  NOT NULL DEFAULT '123456' COMMENT '密码',
  `sex` VARCHAR(2)  NOT NULL DEFAULT '男' COMMENT '性别',
  `birthday` DATETIME  NOT NULL DEFAULT '1997-7-10' COMMENT '生日',
  `address` VARCHAR(50)  NOT NULL DEFAULT '桂林' COMMENT '地址',
  `email` VARCHAR(30)  NOT NULL DEFAULT 'xxx@outlook.com' COMMENT '邮箱',
  `gradeid` INT(5) NOT NULL,
  PRIMARY KEY(`id`)
)ENGINE=INNODB DEFAULT CHARSET=utf8;
-- 创建表的时候没有外键关系
ALTER TABLE `student`
ADD CONSTRAINT `FK_gradeid` FOREIGN KEY(`gradeid`) REFERENCES `grade`(`gradeid`);
-- ALTER TABLE 表 ADD CONSTRAINT 约束名 REFERENCES 哪个表(哪个字段)

以上操作都是物理外键,数据库级别的外键,不建议使用(避免数据库过多造成困扰,了解即可)

最佳实践:

  • 数据库就是单纯的表,只用来存数据,是由行(数据)和列(字段)
  • 想使用多张表的数据,想使用外键(程序去实现)
posted @   十四2001  阅读(13)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示