Mysql中约束的操作

Mysql中约束的操作

1 给指定列添加主键约束

sql 复制代码
把表名为emp中的列名为id添加主键约束
alter table emp add primary key (id);

2 Mysql中的自动增长

sql 复制代码
把自动增长类型添加到id列的主键上
alter table emp modify id int auto_increment;

3删除主键

删除emp中id的主键 、此时id中也有自增长类型、应先去掉自增长

去掉自动增长:

sql 复制代码
alter table emp modify id int;

删除主键

sql 复制代码
alter table emp drop primary key;

主键成功删除

4 添加外键约束

创建表1

departments表包含departments_id,departments_name,location_id;

sql 复制代码
create table departments(de_id int,de_name varchar(30),lo_id int);

给de表的de_id列添加主键约束和自动增长

sql 复制代码
alter table de add primary key(de_id);
alter table de modify de_id int auto_increment;

给emp表添加dep_id 列

sql 复制代码
alter table emp add column dep_it int;

添加成功:

给emp表中的dep_id列中添加外键约束

sql 复制代码
alter table emp add constraint emp_fk foreign key(dep_id) references de(de_id) 

语句解释:修改epm表 添加名为emp_fk的外键约束 指向de表的de_id列

查看emp表

sql 复制代码
show create table emp;

5 删除外键约束

删除名称为emp_fk的外键约束

sql 复制代码
alter table emp drop foreign key emp_fk;

原有的约束被删除

6 添加唯一性约束

sql 复制代码
alter table emp add constraint emp_un unique(name);

修改emp表 给emp-un添加唯一性约束

7 删除唯一性约束

sql 复制代码
alter table emp drop key emp_un;

names的唯一性约束被删除

8 添加非空约束

sql 复制代码
alter table emp modify pct float(4,2) not null;

emp表的pct列被添加非空约束

9 删除非空约束

sql 复制代码
alter table emp modify pct float(4,2) null;

查看emp中的pct列

10 创建表时添加约束

建表: create table employees(id int,name varchar(10),salary float(8,2));

表名:depts (dept_id ,dept_name,location_id) 1是主键且自动增长,2具有唯一性约束,3有非空约束

sql 复制代码
create table depts(dept_id int primary key auto_increment,dept_name varchar(30) unique,location_id int not null);

查询表中约束信息:

相关推荐
什么半岛铁盒2 小时前
C++项目:仿muduo库高并发服务器-------Channel模块实现
linux·服务器·数据库·c++·mysql·ubuntu
muxin-始终如一3 小时前
MySQL与Redis面试问题详解
数据库·redis·mysql
博睿谷IT99_5 小时前
SQL SELECT 语句怎么用?COMPANY 表查询案例(含条件 / 模糊 / 分页)
数据库·sql·mysql
浅拾光º5 小时前
mysql字符串截取,如何在MySQL备份文件中安全截取敏感字符串?
数据库·mysql·安全
鸠摩智首席音效师6 小时前
如何删除 MySQL 数据库中的所有数据表 ?
数据库·mysql·oracle
leo_yu_yty6 小时前
Mysql DBA学习笔记(客户端常用工具)
学习·mysql·dba
小心草里有鬼6 小时前
Linux 数据库 Mysql8 主从复制
linux·运维·数据库·sql·mysql
大白的编程日记.7 小时前
【MySQL学习笔记】数据库的CURD(一)
数据库·学习·mysql
什么半岛铁盒8 小时前
C++项目:仿muduo库高并发服务器--------Any类的实现
linux·服务器·数据库·c++·mysql·github
努力学习的小廉9 小时前
初识MYSQL —— 数据库基础
android·数据库·mysql