这篇文章主要介绍“MySQL约束是什么意思”,在日常操作中,相信很多人在MySQL约束是什么意思问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL约束是什么意思”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
MySQL约束操作
1.非空约束
2.唯一约束
3.主键约束
4.外键约束
5、级联
概念:对表中的数据进行限定,保证数据的正确性,有效性和完整性。
分类:
主键:primary key
非空约束:not null
唯一约束:unique
外键约束:foreign key
not null
,值不能为空。
创建表时添加非空约束:
CREATE TABLE stu( id INT, NAME VARCHAR(20) NOT NULL );
创建表完后,添加非空约束
ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL;
删除非空约束
ALTER TABLE stu MODIFY NAME VARCHAR(20);
unique,
值不能重复。
创建表时添加唯一约束
CREATE stu( id INT; phone_number VARCHAR(20) UNIQUE );
注意:
mysql
中,唯一约束限定的列的值可以有多个null
。
删除唯一约束
ALTER TABLE stu DROP INDEX phone_number;
创建表完后,添加唯一约束
ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;
primary key,
非空且唯一。
一张表只能有一个字段为主键。
主键就是表中记录的唯一标识。
创建表时添加主键约束
CREATE TABLE stu( id INT PRIMARY KEY, NAME VARCHAR(20) );
删除主键
ALTER TABLE stu DROP PRIMARY KEY;
创建表完后,添加主键
ALTER TABLE stu MODIFY id INT PRIMARY KEY ;
这里补充一个知识点:自动增长
概念:如果某一列是数值类型的,使用auto_increment
可以来完成自动增长。
例子:
在创建表时,添加主键约束,并且完成主键自动增长
CREATE TABLE stu( id INT PRIMARY KEY AUTO_INCREMENT, NAME VARCHAR(20) ); #自动增长会根据当前列的最后一行的值往后增加。
删除自动增长
ALTER TABLE stu MODIFY id INT; #这样只会删除自动增长,主键删不掉。
创建表完后,在添加自动增长
ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;
foreign ley
,让表与表产生关系,从而保证数据的正确性。
在创建表时,可以添加外键
CREATE TABLE 表名( ... 外键列 CONSTRAINT 外键名称 FOREIGN KEY (外键列名称) REFERENCES 主表名称(主表列名称) );
删除外键
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
创建表之后,添加外键
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);
添加级联操作
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称) ON UPDATE CASCADE ON DELETE CASCADE ;
级联删除
ON UPDATE CASCADE
到此,关于“MySQL约束是什么意思”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。