SQL增加主键约束的条件

结论

常见认为设为主键的条件为:

  • 值唯一
  • 不含空值
    • 具体实施中会出现各种问题

添加主键约束的条件细则:

  • 值唯一
  • 数据中不含空值
  • 在定义时需要not null约束(使用check约束不行

验证实验

接下来我做了关于这个细则的验证实验:


设Student表中的列为:

  • Sno( char(5),状态)
  • Sname(varchar(10),null)
  • Sage(int,null)

建立Student表的sql语句为:

sql 复制代码
create table Student(
	Sno  char(5)
	Sname  varchar(10)
	Sage  int
)

目的:想将Sno设为Student的主键。

需要根据Sno的状态分类讨论

若Sno中无null值

sql 复制代码
alter table Student
add constraint PK1 primary key(sno)

结果:会报错,因为Sno只是目前暂时没有空值,但有含null值的可能性。因此需要Sno增加约束条件,消除其含null值的可能性

思路有两种,一种通过check约束限制Sno不含空值、一种在定义Sno时限制。

  • check约束限制
sql 复制代码
alter table student
add constraint C1 check(sno is not null)

成功添加check约束后再次尝试。发现仍然失败。这个方法行不通

  • 定义限制
    为保证实验的严谨,需要控制变量,先将刚刚的C1限制删除再进行定义限制。
sql 复制代码
alter table student
alter column sno char(5) not null

再尝试增加主键约束。发现成功添加

若Sno中含null值

数据中含null值当然无法设置主键约束。但是在这一节可以进一步的佐证,为什么仅满足check约束无法成功添加主键约束。

  • 尝试添加check约束限制
    会报错,因为当前表中sno已经有null值
sql 复制代码
alter table student 
add check(sno is not null)
  • 强制添加check约束
    通过增加with nocheck字段可以强制添加check约束。这样的效果是,不会去检查先前的空值,但会检查之后插入的元组
sql 复制代码
alter table student 
with nocheck add check(sno is not null)

因此,会出现列Sno,明明有not null的check约束,但数据中仍有null值的问题。故check约束并不能保证Sno值不为null的条件,也就不能成功添加主键约束。

相关推荐
计算机安禾3 分钟前
【数据库系统原理】第9篇:SQL的结构化思维:DDL、DML与DCL的职责分离
数据库·sql·oracle
计算机安禾7 分钟前
【数据库系统原理】第12篇:视图机制:外模式在SQL层级的逻辑数据独立性实现
数据库·sql·oracle
前进的李工11 分钟前
MySQL性能优化:索引与子查询实战技巧
数据库·sql·mysql·性能优化
疯狂成瘾者19 分钟前
API Key 生成和鉴权机制:从随机凭证生成到请求拦截校验
数据库·oracle
Volunteer Technology32 分钟前
SpringSecurity中的权限管理
java·数据库·servlet
段ヤシ.41 分钟前
回顾Java知识点,面试题汇总Day13:数据库MySQL(持续更新)
java·数据库·mysql
mN9B2uk171 小时前
在Qt中使用SQLite数据库
数据库·qt·sqlite
迷枫7121 小时前
达梦 SQL 执行计划操作符与 TRACE、ET 学习笔记
笔记·sql
network_tester1 小时前
SENT/PSI5传感器TSN集成测试:打通传统传感与未来车载网络的“最后一公里”
数据库·网络协议·tcp/ip·自动驾驶·信息与通信·信号处理·tcpdump
桌面运维家1 小时前
校园机房vDisk IDV云桌面建设方案价格参考
linux·服务器·数据库