数据库之主键、联合主键

参考文章:数据库之主键、联合主键

一、主键、联合主键简介

数据库主键是用来标记数据记录唯一性的列,不能为空,不能重复。

主键具有的特点:唯一性非空性

数据库联合主键:可以将多个列同时作为主键。(当多个列一起作为主键时,这里面的列均不能为空,但列值可以重复(不能所有的列值均一样,至少有一个不同))

当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键。一个表只能有一个·PRIMARY KEY约束,而且 PRIMARY KEY 约束中的列不能接受空值。

二、联合主键练习

下面使用Navicat进行练习

新建一个SC

在这里插入图片描述

后面的小钥匙就代表了主键,一个为主键、两个或以上为联合主键,再点一下,可以取消。

在这里插入图片描述

选择Sno(学号)、Cno(课程号)作为联合主键。

插入数据:

INSERT INTO `sc` VALUES (1001, 2001, 68);
INSERT INTO `sc` VALUES (1002, 2001, 78);

在这里插入图片描述
此时插入:

INSERT INTO `sc` VALUES (1002, 2001, 88); #失败
INSERT INTO `sc` VALUES (1002, 2002, 88); #成功

在这里插入图片描述
注意:若表结构中有多个列一起作为主键,则它们均不能为空,(即“不是null” 要选),否则会报错!

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值