1.任务:给表添加常用的约束。
2.相关知识
在数据库的使用过程中我们经常要限制属性的取值,比如有些属性不能为空,就需要添加非空约束,本关要求完成常用约束的添加和定义。
目录
(1)唯一约束
(2)添加非空约束
(3)使用默认约束
(4)设置表的属性值自动增加
EDUCODER练习:
(1)唯一约束
唯一约束(Unique Constraint)
要求该列唯一,允许为空,但是只能有一个空值。唯一约束可以确保一列或者几列不出现重复值。
定义部门表的部门名称唯一,SQL
语句如下:关键词 UNIQUE
。
CREATE TABLE t_dept(
id INT PRIMARY KEY,
name VARCHAR(22) UNIQUE,
location VARCHAR(50)
);
(2)添加非空约束
关键词:NOT NULL
;
例如:
CREATE TABLE t_dept(
id INT PRIMARY KEY,
name VARCHAR(22) NOT NULL,
location VARCHAR(50)
);
(3)使用默认约束
默认约束:即给字段一个默认值。
关键词:DEFAULT;
例如:
CREATE TABLE t_emp(
id INT PRIMARY KEY,
name VARCHAR(22),
sex VARCHAR(2) DEFAULT '男'
) DEFAULT CHARSET=utf8;
注意:
- 如果是添加字符串型默认值要使用单引号,如果是整型则不需要加任何符号;
- 如果要添加的是中文默认值,则需要加上
DEFAULT CHARSET=utf8;
使用英文字符则不需要。
(4)设置表的属性值自动增加
id | name |
---|---|
1 | 张三 |
2 | 李四 |
ID每次自动加一 | 姓名 |
... | XXX |
10 | XXX |
关键词:AUTO_INCREMENT
,默认情况下初始值和增量都为1
。
例如:
CREATE TABLE t_tmp(
id INT PRIMARY KRY AUTO_INCREMENT,
name VARCHAR(32)
);
EDUCODER练习:
编程要求
在数据库TestDb
中创建表t_user
,表结构如下:
字段名称 | 数据类型 | 备注 |
---|---|---|
id | INT | 用户ID,主键,自动增长 |
username | varchar(32) | 用户名,非空,唯一 |
sex | varchar(4) | 性别,默认“m” |
提示:若要给字段添加两个或者两个以上的约束,约束之间以空格隔开即可。
提示:可使用如下语句删除表。
DROP TABLE 表名;