SQL CHECK 约束
CHECK 约束用于限制列中的值的范围。
如果对单个列定义 CHECK 约束,那么该列只允许特定的值。
如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限制。
create TABLE STUDENTS
(
ID INT NOT NULL CHECK(ID > 5),
NAME VARCHAR(20)
)
在上述表结构中显得ID的值大于5.我们也可以指定多个约束。
CREATE TABLE STUDENTS
(
ID INT NOT NULL,
NAME VAHRCHAR(20) NOT NULL,
TEL CHAR(11),
ADDRESS VARCHAR(20),
CONSTRAINT CHEAK_K CHECK(ID>5 AND NAME LIKE('%DD'))
)
在已存在的表结构中
ALTER TABLE STUDENTS
ADD CHECK(NAME LIKE('D%')
OR
ALTER TABLE STUDENTS
ADD CONSTRAINT CHECK_K CHECK(ID>4 AND NAME=‘爱的’)
删除已存在的约束
ALTER TABLE STUDENTS
DROP CONSTRAINT CHECK_K
PS:在mysqk中check只是为了和其他数据库兼容,在里面不起作用。
SQL DEFAULT 约束
DEFAULT 约束用于向列中插入默认值。
如果没有规定其他的值,那么会将默认值添加到所有的新纪录。
我们在创建表的时候为某列添加一个默认值。SQL CREATE INDEX 语句
CREATE INDEX 语句用于在表中创建索引。
在不读取整个表的情况下,索引使数据库应用程序可以更快地查找数据
索引
您可以在表中创建索引,以便更加快速高效地查询数据。
用户无法看到索引,它们只能被用来加速搜索/查询。
注释:更新一个包含索引的表需要比更新一个没有索引的表更多的时间,这是由于索引本身也需要更新。因此,理想的做法是仅仅在常常被搜索的列(以及表)上面创建索引。
CREATE INDEX SRUDENTS_INDEX ON STUDENTS(ID);//在students表的id列建立index。SQL CREATE UNIQUE INDEX 语法
在表上创建一个唯一的索引。唯一的索引意味着两个行不能拥有相同的索引值。
CREATE UNIQUE INDEX ID_INDEX ON STUDENTS(ID)
如果您希望以降序索引某个列中的值,您可以在列名称之后添加保留字 DESC:
CREATE INDEX ID_INDEX ON STUDENTS (ID DESC);
假如您希望索引不止一个列,您可以在括号中列出这些列的名称,用逗号隔开:
CREATE INDEX IN_NAME_INDEX ON STUDENTS(ID, NAME);