一、外键(了解)
外键(了解)
方式一:在创建表的时候,增加约束(麻烦,比较复杂)
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 哪个表(哪个字段)
以上操作都是物理外键,数据库级别的外键,不建议使用(避免数据库过多造成困扰,了解即可)
最佳实践:
- 数据库就是单纯的表,只用来存数据,是由行(数据)和列(字段)
- 想使用多张表的数据,想使用外键(程序去实现)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现