当前位置:网站首页 > SQL数据库编程 > 正文

mysql主键,外键(mysql主键外键怎么用)



时间煮雨
@R星校长

主键用法&意义

主键,是表中一列或者多列的组合,主键约束(Primary Key Constraint)要求主键列的数据唯一,并且不允许为空,主键能够唯一的标识表中的每一条记录,可以结合外键来定义与不同数据表之间的关系。
怎么理解主键呢?我们知道数据库中的表可以存放很多数据,如果把表中的每一个数据比作一个人的话,那么表的主键就可以看做是人的身份证。

(1) 在定义列的同时指定主键:

在这里插入图片描述

(2) 在定义完所有列之后指定主键。

在这里插入图片描述

多字段联合主键

在开发中还有一种情况很常见,就是将几个字段联合在一起作为主键,那这个在代码中怎么实现呢?
举个例子,我们将员工的名字和部门ID联合起来作为主键:
下面展示一些 。

 
  

语句执行后,会将namedeptId字段组合成为表t_emp2的多字段组合主键。

主外键键用法&意义
外部关键字

在以后我们统一将外部关键字叫做外键,外键就是另一张表中的主键

再问:怎么保证的呢?
答:看图。
在这里插入图片描述
如图有两张表,是的外键,是 表的主键, 如果我们要删除 表中为的字段,程序是会报错的,因为表中有数据和为的字段关联了,是不能删除的,这样子就保证了数据的一致性和完整性


继续问: 那怎么才能删除呢?
接着答: 需要先删除表中为1的两个字段。

如何给表添加外部关键字

在MySQL中给表中字段添加外键约束的语法规则如下:

  1. CONSTRAINT 外键名 FOREIGN KEY 字段名 REFERENCES 主表名(主键名)

举个例子:现在有两张表,、如下。

t_dept表

字段名称 数据类型 备注 deptld INT 部门编号 name VARCHAR(22) 部门名称 location VARCHAR(50) 部门位置

t_emp表

字段名称 数据类型 备注 id INT 员工编号 name VARCHAR(22) 员工名称 location VARCHAR(50) 部门ID(外键类型必须和对应主键类型一致)

我们来创建两张表,并给员工表添加外键:

 
  

实际操作如图:
在这里插入图片描述

祝你成功,学的愉快!😊

到此这篇mysql主键,外键(mysql主键外键怎么用)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • mysql导入sql文件没有表(mysql5.7导入sql文件)2026-01-29 07:45:08
  • yml文件配置(yml文件配置mysql)2026-01-29 07:45:08
  • sql文件如何打开运行(sql server怎么打开sql文件)2026-01-29 07:45:08
  • 如何连接redis数据库(redis怎么连接mysql)2026-01-29 07:45:08
  • sqlldr(Sqlldr多字节字符错误)2026-01-29 07:45:08
  • mysql添加主键约束语句(mysql 添加主键约束)2026-01-29 07:45:08
  • druid监控页面打不开(druid监控sql不出现)2026-01-29 07:45:08
  • sql文件转csv文件(sqlserver导出csv文件)2026-01-29 07:45:08
  • sql文件(sql文件怎么导入mysql)2026-01-29 07:45:08
  • mysql查看主键索引(mysql主键索引类型)2026-01-29 07:45:08
  • 全屏图片