数据库——SQL约束窗口函数介绍
4.SQL约束介绍
(1)主键约束
A、基本内容
- 基本内容
- p r i m a r y primary primary k e y key key约束唯一表示数据库中的每条记录
- 主键必须包含唯一的值(UNIQUE)
- 主键不能包含NULL值(NOT NULL)
- 每个表都应该有一个主键,并且每个表只能有一个主键
- 遵循原则
- 逐渐应当是对用户没有意义的
- 永远也不要更新主键
- 主键不应该包含动态变换的数据,如时间戳,创建时间列,修改时间列
- 逐渐应当由计算机自动生成
B、添加主键约束
-
创建表时添加主键
#创建数据表时添加 create table person(id INT PRIMARY KEY,last_name VARCHAR(100),first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100) );
最终输出的表
Field | Type | Null | Key | Default | Extra |
---|---|---|---|---|---|
id | int(20) | NO | PRI | ||
last_name | varchar(100) | YES | |||
first_name | varchar(100) | YES | |||
address | varchar(100) | YES | |||
city | varchar(100) | YES |
-
创建表后添加主键
# 创建后添加约束 create table person(id INT,last_name VARCHAR(100),first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100) );
- 在创建表后,可以使用
ALTER TABLE
关键字添加主键
ALTER TABLE category ADD PRIMARY KEY(cid);
- 在创建表后,可以使用
C、删除主键约束
- 格式:
alter table category drop primary key;
D、自动增长列
auto_increment
(自动增长列)关键字:我们通常在每次插入新记录时,数据库自动生成字段的值
- 注意:自动增长列类型必须是整型,自动增长列必须为键(一般是主键),自动增长常与主键约束配合使用
- 创建表时添加自动增长
CREATE TABLE person2(id INT PRIMARY KEY AUTO_INCREMENT,last_name VARCHAR(100),first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100)
)
最终输出的表
Field | Type | Null | Key | Default | Extra |
---|---|---|---|---|---|
id | int(20) | NO | PRI | auto_increment | |
last_name | varchar(100) | YES | |||
first_name | varchar(100) | YES | |||
address | varchar(100) | YES | |||
city | varchar(100) | YES |
- 在创建表之后添加自动增长
ALTER TABLE person2 CHANGE id id INT AUTO_INCERMENT;
-
示例
向person中添加数据时,可以不为id字段设置值,或可以设置成null,数据库将自动维护主键值
输入
insert into person2(first_name,last_name) values('Bill','Gates'); 或 insert into person2(id,first_name,last_name) values(null,'Bill','Gates');
在输入
select * from person2
语句之后,会输出id last_name first_name address city 1 Gates Bill 2 Gates Bill 可以看到,从上往下,id的值是
-
其他
当主键不是自增长类型时
-
不为 id 字段设置值
执行插入语句时若不指定
id
字段值,数据库会报错。因为非自增长主键字段不允许有空值(一般定义为主键时会设置为NOT NULL
),缺少主键值就无法满足数据完整性约束 。例如在 MySQL 中执行insert into person2(first_name,last_name) values('Bill','Gates');
会报错,提示主键字段不能为空 。 -
将 id 设置成 null
同样会报错。因为主键具有唯一性和非空性约束,
null
值既不符合非空要求,也难以保证唯一性(多个null
无法区分 ) 。像执行insert into person2(id,first_name,last_name) values(null,'Bill','Gates');
,数据库会提示违反主键约束相关错误 。
总之,非自增长主键要求在插入数据时必须明确指定一个符合其数据类型且唯一的有效值。
-
(2)非空约束
-
NOTNULL 约束强制列不进行NULL值,强制字段始终包含值,故说明如果不向字段中添加值,就无法插入新记录或者更新记录
-
示例
CREATE TABLE person3(id INT PRIMARY KEY,last_name VARCHAR(100) NOT NULL,first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100)
)
最终输出的表
Field | Type | Null | Key | Default | Extra |
---|---|---|---|---|---|
id | int(20) | NO | PRI | auto_increment | |
last_name | varchar(100) | NO | |||
first_name | varchar(100) | YES | |||
address | varchar(100) | YES | |||
city | varchar(100) | YES |
(3)唯一约束
-
基础
- UNIQUE约束唯一标识数据库表中的每条记录
- UNIQUE和PRIMARY KEY 约束均为列或列集合提供了唯一性的保证
- PRIMARY KEY 拥有自动定义的UNIQUE约束
-
注意
- 每个表中可以有多个UNIQUE约束,但是每个表只能有一个PERIMARY KEY约束
-
示例
CREATE TABLE person3(id INT PRIMARY KEY,last_name VARCHAR(100) UNIQUE,first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100)
)
最终输出的表
Field | Type | Null | Key | Default | Extra |
---|---|---|---|---|---|
id | int(20) | NO | PRI | auto_increment | |
last_name | varchar(100) | YES | UNI | ||
first_name | varchar(100) | YES | |||
address | varchar(100) | YES | |||
city | varchar(100) | YES |
(4)默认值约束
- 当不填写字段对应的值会使用默认值,如果填写时以填写的为准
- 示例
CREATE TABLE person3(id INT PRIMARY KEY,last_name varchar(100) NOT NULL,first_name varchar(100),address varchar(100),city varchar(100) DEFAULT '北京'
)
最终输出的表
Field | Type | Null | Key | Default | Extra |
---|---|---|---|---|---|
id | int(20) | NO | PRI | auto_increment | |
last_name | varchar(100) | YES | UNI | ||
first_name | varchar(100) | YES | |||
address | varchar(100) | YES | |||
city | varchar(100) | YES | 北京 |
四、窗口函数
- 基本语法:
SELECT SUM() OVER(PARTITION BY ___ ORDER BY ___) FROM TABLE;
PARTITION BY
与GROUP BY
的区别GROUP BY
分组聚合之后,分组字段有几个取值,就会返回几条结果PARTITION BY
返回的结果和原始数据表的条目数是一样的