MySQL约束操作

概念:对表中的数据进行限定,保证数据的正确性,有效性和完整性。

分类:

  • 主键:primary key
  • 非空约束:not null
  • 唯一约束:unique
  • 外键约束:foreign key

1.非空约束

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);

创建表时添加唯一约束

CREATE stu( id INT; phone_number VARCHAR(20) UNIQUE);

删除唯一约束

ALTER TABLE stuDROP INDEX phone_number;
ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;
  • 非空且唯一。
  • 一张表只能有一个字段为主键。
  • 主键就是表中记录的唯一标识。

创建表时添加主键约束

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 stuMODIFY id INT;#这样只会删除自动增长,主键删不掉。
ALTER TABLE stuMODIFY id INT AUTO_INCREMENT;

在创建表时,可以添加外键

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

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
  3. MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
  4. Android(安卓)- Manifest 文件 详解
  5. Android的Handler机制详解3_Looper.looper()不会卡死主线程
  6. Selector、shape详解(一)
  7. android2.2资源文件详解4--menu文件夹下的菜单定义
  8. android从服务器下载文件(php+apache+win7+MySql)
  9. Android发送短信方法实例详解

随机推荐

  1. Android事件分发与消费
  2. 使用Android(安卓)Memory Profiler
  3. 有关Android线程的学习
  4. Android学习之路(一)之 Android文件简单介
  5. Android(安卓)ListView滑动过程中图片显
  6. Android 程式开发:(一)详解Activity —— 1.
  7. Android撬动IT市场的新支点!
  8. Android的init过程详解(一)
  9. 《程序人生 —— Android实现录音、播音
  10. Android 不要把android做成ios!