重复菜鸟教程中sql练习,由此记录。
1.SQL Constraints
SQL 约束用于规定表中的数据规则,约束可以在创建表时规定(通过 CREATE TABLE 语句),或者在表创建之后规定(通过 ALTER TABLE 语句)。
CREATE TABLE table_name
(
column_name1 data_type(size) constraint_name,
column_name2 data_type(size) constraint_name,
column_name3 data_type(size) constraint_name,
....
);
- NOT NULL - 指示某列不能存储 NULL 值。
- UNIQUE - 保证某列的每行必须有唯一的值。
- PRIMARY KEY - NOT NULL 和 UNIQUE 的结合。确保某列(或两个列多个列的结合)有唯一标识,有助于更容易更快速地找到表中的一个特定的记录。
- FOREIGN KEY - 保证一个表中的数据匹配另一个表中的值的参照完整性。
- CHECK - 保证列中的值符合指定的条件。
- DEFAULT - 规定没有给列赋值时的默认值。
2.SQL NOT NULL约束
NOT NULL 约束强制字段始终包含值。这意味着,如果不向字段添加值,就无法插入新记录或者更新记录。
3.SQL UNIQUE 约束
UNIQUE 约束唯一标识数据库表中的每条记录。
UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。
PRIMARY KEY 约束拥有自动定义的 UNIQUE 约束。
请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。
删除约束与多个约束的定义与删除
--多个约束定义
ALTER TABLE persons
ADD CONSTRAINT uc_person UNIQUE (ID,name)
--多个约束撤销
ALTER TABLE persons
DROP CONSTRAINT uc_person
--在创建table时定义约束
CREATE TABLE Persons
(
P_Id int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
UNIQUE (P_Id)
)
--在创建table时定义多个约束
CREATE TABLE Persons
(
P_Id int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT uc_PersonID UNIQUE (P_Id,LastName)
)
4.SQL PRIMARY KEY
PRIMARY KEY 约束唯一标识数据库表中的每条记录。主键必须包含唯一的值。主键列不能包含 NULL 值。每个表都应该有一个主键,并且每个表只能有一个主键。
语法与UNIQUE类似,可以在首次创建table时定义主键,也可以在后面alter添加主键。
---创建table时定义主键
CREATE TABLE persons
(
id int NOT NULL,
name varchar(255) NOT NULL,
age int NOT NULL,
PRIMARY KEY (id)
)
---后期添加主键定义
CREATE TABLE persons
(
id int NOT NULL,
name varchar(255) NOT NULL,
age int NOT NULL
)
ALTER TABLE persons
ADD PRIMARY KEY (id)
---撤销PRIMARY KEY约束
ALTER TABLE persons
DROP PRIMARY KEY
如需命名 PRIMARY KEY 约束,并定义多个列的 PRIMARY KEY 约束,请使用下面的 SQL 语法
---创建table时定义主键
CREATE TABLE persons
(
id int NOT NULL,
name varchar(255) NOT NULL,
age int NOT NULL,
CONSTRAINT pk_person PRIMARY KEY (id,name)
)
---后期添加主键定义
CREATE TABLE persons
(
id int NOT NULL,
name varchar(255) NOT NULL,
age int NOT NULL
)
ALTER TABLE persons
ADD CONSTRAINT pk_person PRIMARY KEY (id,name)
---撤销PRIMARY KEY约束
ALTER TABLE persons
DROP PRIMARY KEY
5.SQL FOREIGN KEY约束
一个表中的 FOREIGN KEY 指向另一个表中的 UNIQUE KEY(唯一约束的键)。
FOREIGN KEY 约束用于预防破坏表之间连接的行为。FOREIGN KEY 约束也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。
请注意,"Orders" 表中的 "P_Id" 列指向 "Persons" 表中的 "P_Id" 列。
"Persons" 表中的 "P_Id" 列是 "Persons" 表中的 PRIMARY KEY。
"Orders" 表中的 "P_Id" 列是 "Orders" 表中的 FOREIGN KEY。
语法如下:
---在创建table时设置外键
CREATE TABLE Orders
(
O_Id int NOT NULL,
OrderNo int NOT NULL,
P_Id int,
PRIMARY KEY (O_Id),
FOREIGN KEY (P_Id) REFERENCES Persons(P_Id)
)
---如需命名 FOREIGN KEY 约束,并定义多个列的 FOREIGN KEY 约束,请使用下面的 SQL 语法:
CREATE TABLE Orders
(
O_Id int NOT NULL,
OrderNo int NOT NULL,
P_Id int,
PRIMARY KEY (O_Id),
CONSTRAINT fk_PerOrders FOREIGN KEY (P_Id)
REFERENCES Persons(P_Id)
)
---后期添加外键
ALTER TABLE Orders
ADD FOREIGN KEY (P_Id)
REFERENCES Persons(P_Id)
---后期添加多个外键
ALTER TABLE Orders
ADD CONSTRAINT fk_PerOrders
FOREIGN KEY (P_Id)
REFERENCES Persons(P_Id)
---撤销FOREIGN KEY 约束
ALTER TABLE Orders
DROP FOREIGN KEY fk_PerOrders
6.SQL CHECK约束
CHECK 约束用于限制列中的值的范围。如果对单个列定义 CHECK 约束,那么该列只允许特定的值。如果对一个表定义 CHECK 约束,那么此约束会基于行中其他列的值在特定的列中对值进行限制。
#创建时即设置CHECK
CREATE TABLE person
(P_id int NOT NULL,
Name varchar(255) NOT NULL,
City varchar(255) NOT NULL,
Age int NOT NULL,
CHECK (P_id>0)
);
#多列设置CHECK
CREATE TABLE person
(P_id int NOT NULL,
Name varchar(255) NOT NULL,
City varchar(255) NOT NULL,
Age int NOT NULL,
CONSTRAINT chk_person CHECK (P_Id>0 AND City='Sandnes')
);
当表已经被创建时,修改check信息。
#修改check信息
ALTER TABLE persons
ADD CHECK (P_id>0);
#修改check信息多列
ALTER TABLE persons
ADD CONSTRAINT chk_persons CHECK(P_id>0 AND City="Sandness")
#撤销CHECK约束
ALTER TABLE person
DROP CHECK chk_persons
7. SQL DEFAULT约束
DEFAULT 约束用于向列中插入默认值。如果没有规定其他的值,那么会将默认值添加到所有的新记录。
#在创建时设置defalut
CREATE TABLE Persons
(
P_Id int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255) DEFAULT 'Sandness'
)
#已有table,修改时设置default
ALTER TABLE Persons
ALTER City SET DEFAULT "Sandness"
#撤销DEFAULT约束
ALTER TABLE Persons
ALTER City DROP DEFAULT
8.SQL CREATE INDEX语句
CREATE INDEX 语句用于在表中创建索引。在不读取整个表的情况下,索引使数据库应用程序可以更快地查找数据。
注释:更新一个包含索引的表需要比更新一个没有索引的表花费更多的时间,这是由于索引本身也需要更新。因此,理想的做法是仅仅在常常被搜索的列(以及表)上面创建索引。
#创建一个简单的index,允许重复的值
CREATE INDEX index_name
ON table_name (column_name)
#在表上创建一个唯一的索引
CREATE UNIQUR INDEX index_name
ON table_name (column_name)
9.SQL撤销索引,撤销表,以及撤销数据库
#DROP INDEX 用于删除表中的索引
ALTER TABLE table_name DROP INDEX index_name
#DROP TBALE 用于删除表
DROP TABLE table_name
#DROP DATABASE用于删除数据库
DROP DATABASE databse_name
#TRUNCATE TABLE用于删除表内数据,但是不删除表本身
TRUNCATE TABLE table_name
10.SQL ALTER TABLE 语句
ALTER TABLE 用于在已有的表中添加,删除或修改列。
#添加列
ALTER TABLE table_name
ADD column_name datatype
#删除列
ALTER TABLE table_name
DROP COLUMN column_name
#修改表中的数据类型
ALTER TABLE table_name
MODIFY COLUMN column_name datatype
以上,记录本人学习过程。