浅谈MYSQL主键约束和唯一约束的区别
主键约束
PRIMARY KRY 主键 是唯一的 一张表只能有一个主键
AUTO_INCREMENT 一定要和主键连用
主键一定是非空的 NOT NULL
特点:不能为空,不重复
##没有约束 Create table stu0( Id int Name varcahr(50) ) Insert into stu0(name)value(“张三丰”); ##方式一:创建表,并且添加主键约束 Create table stu1( Id int primary key; Name varchar(50) ) ##方式二: Create table stu2( Id int, Name varchar(50), Primary key(name) )
成功: insert intostu1(in,name)value(“2,张三丰”);成功
测试一: insert into stu(id,name)value(null,”张三丰”);#失败,提示不能为空
测试二:
插入重复值:报错
Duplicate entry'2' for key ‘PRIMARY'
Select *from stu1;
唯一约束
UNIQUE KEY 唯一约束
唯一约束可以保证数据的唯一性
每张数据表可以有存在多个唯一约束
唯一约束(unique)
不重复,可以为空
##给名字添加唯一 的约束 Create table stu3( Id int primary key, Name varchar(50) unique ) Insert into stu3(id,name)value(1,”张三丰”); Insert into stu3(id,name)value(2,”张三丰”); ERROR 1062(23000):Duplicate entry ‘张三丰'for key ‘name' Insert into stu3(id,name)value(2,”张三”);
到此这篇关于浅谈MYSQL主键约束和唯一约束的区别的文章就介绍到这了,更多相关MYSQL主键约束和唯一约束 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
解决MySQL登录报错1045-Access denied for user 'root'@
这篇文章主要给大家介绍了关于解决MySQL登录报错1045-Access denied for user ‘root‘@‘‘(using password:YES)的相关资料,文中一步步将解决的办法介绍的非常详细,需要的朋友可以参考下2023-07-07Mysql8报错this is incompatible with sql_mo
这篇文章主要介绍了Mysql8报错this is incompatible with sql_mode=only_full_group_by问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-01-01
最新评论