Sql语句练习三

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 约束用于向列中插入默认值。

如果没有规定其他的值,那么会将默认值添加到所有的新纪录。

我们在创建表的时候为某列添加一个默认值。
CREATE TABLE STUDENT(ID INT NOT NULL DEFAULT 0, NAME CARCHAR(20))
我们可以配合使用一些函数来使用。
CREATE TABLE STUDENTS(ID INT , NAME VARCHAR(20), BRITHERDAY DATE DEFAULT GETDATE());
添加DEFAULT约束。
ALTER TABLE STUDENTS ALTER ID SET DEFAULT 0;//MYSQL
ALTER TABLE STUDENTS ALTER COLUMN NAME SET DEFAULT 'HELLO';
删除DEFAULT约束.
ALTER TABLE STUDENTS ALTER ID DROP DEFAULT;//MYSQL
ALTER TABLE STUDENTS ALTER COLUMN ID DROP 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);






  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值