约束 Constraint

完整性性约束
     1、实体完整性
    主键约束: primary key
    保证每一条记录的唯一性,字段的值必须是唯一的,且不能为null
    一张表只能有一个主键,建议添加主键
    
     2、域完整性
        非空约束   not null
        保证某一字段的值不能为  null
        
        唯一性约束  unique
        保证某一字段的值不能重复,可以为null,但是只能有1个
        
        默认约束   default
        在插入数据时,如果没有填写,提供默认值
        
     3、自定义完整性
    检查约束  check
    mysql 不支持
    
     4、引用完整性
    外键约束  foreign key

一、主键

创建主键的三种方式:

1.创建表时,在字段描述处直接创建   

eg:pid INT PRIMARY KEY,

2.创建表时,在constraint区域,创建指定字段为主键

eg:CONSTRAINT pk_person3 PRIMARY KEY(pid)

3.创建表后,通过修改表结构添加主键

eg:ALTER TABLE person6 ADD CONSTRAINT pk_p6 PRIMARY KEY(pid);
        ALTER TABLE person6 ADD PRIMARY KEY(pid);

删除主键
ALTER TABLE person6 DROP PRIMARY KEY;

默认地,AUTO_INCREMENT 的开始值是 1,如果希望修改起始值,使用下列 SQL 语法:    
ALTER TABLE Persons AUTO_INCREMENT=100

二、非空约束

创建表时,在字段描述后直接声明

eg:pname VARCHAR(20) NOT NULL,

注:使用数据库的工具软件时,给非空字段插入空值可能并不报错,只是警告,这显然是不正确的;而在命令行下操作不能插入数据,会明确提示该字段非空。

三、唯一性约束

创建唯一性约束也有三种方式,和主键约束完全一致

删除唯一性约束,须特别注意,使用如下SQL语句:

ALTER TABLE persons DROP INDEX 名称 ;  特别注意下划线部分,使用的是index,而不是unique

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lzk_bk

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值