在mysql中 主键约束的关键字是_mysql的约束

主键约束

主键(PRIMARY KEY)的完整称呼是“主键约束”,是 MySQL 中使用最为频繁的约束。一般情况下,为了便于 DBMS 更快的查找到表中的记录,都会在表中设置一个主键。

主键分为单字段主键和多字段联合主键,本节将分别讲解这两种主键约束的创建、修改和删除。

使用主键应注意以下几点:

每个表只能定义一个主键。

主键值必须唯一标识表中的每一行,且不能为 NULL,即表中不可能存在有相同主键值的两行数据。这是唯一性原则。

一个字段名只能在联合主键字段表中出现一次。

联合主键不能包含不必要的多余字段。当把联合主键的某一字段删除后,如果剩下的字段构成的主键仍然满足唯一性原则,那么这个联合主键是不正确的。这是最小化原则。

1)设置单字段主键

在 CREATE TABLE 语句中,通过 PRIMARY KEY 关键字来指定主键。

在定义字段的同时指定主键,语法格式如下:

PRIMARY KEY [默认值]

mysql> create table userinfo (

-> user_id int(10) NOT NULL auto_increment COMMENT'用户ID',

-> user_name varchar(16) NOT NULL COMMENT '姓名',

-> user_sex char(2) NOT NULL COMMENT '性别',

-> user_age tinyint(2) default '0' COMMENT '年龄',

-> PRIMARY KEY(user_id)

-> );

Query OK, 0 rows affected (0.02 sec)

删除主键约束

mysql> alter table userinfo drop primary key;

主键自增长

在mysql中,当主键定义为自增长以后,这个主键的值就不再需要用户输入数据了,而由数据系统根据定义自动赋值,每增加一条 记录,主键会自动以相同的步长进行增长。

语法如下:

字段名 数据类型  AUTO_INCREMENT

默认情况下,AUTO_INCREMENT 的初始值是 1,每新增一条记录,字段值自动加 1。

一个表中只能有一个字段使用 AUTO_INCREMENT 约束,且该字段必须有唯一索引,以避免序号重复(即为主键或主键的一部分)。

AUTO_INCREMENT 约束的字段必须具备 NOT NULL 属性。

AUTO_INCREMENT 约束的字段只能是整数类型(TINYINT、SMALLINT、INT、BIGINT 等)。

AUTO_INCREMENT 约束字段的最大值受该字段的数据类型约束,如果达到上限,AUTO_INCREMENT 就会失效。

指定自增字段初始值

mysql> alter table userinfo auto_increment=1000;

外键约束(FOREIGN KEY)

MYSQL外键约束是表的一个特殊字段,经常与主键约束一起使用,外键用来建立主表与从表的关联关系,为两个表的数据建立连接,约束两个表中数据的一致性和完整性。

主表删除某条记录时,从表中与之对应的记录也必须有相应的改变。一个表可以有一个或多个外键,外键可以为空值,若不为空值,则每一个外键的值必须等于主表中主键的某个值。

定义外键时,需要遵守下列规则:

主表必须已经存在于数据库中,或者是当前正在创建的表。如果是后一种情况,则主表与从表是同一个表,这样的表称为自参照表,这种结构称为自参照完整性。

必须为主表定义主键。

主键不能包含空值,但允许在外键中出现空值。也就是说,只要外键的每个非空值出现在指定的主键中,这个外键的内容就是正确的。

在主表的表名后面指定列名或列名的组合。这个列或列的组合必须是主表的主键或候选键。

外键中列的数目必须和主表的主键中列的数目相同。

外键中列的数据类型必须和主表主键中对应列的数据类型相同。

在创建表时设置外键约束

在 CREATE TABLE 语句中,通过 FOREIGN KEY 关键字来指定外键,具体的语法格式如下:

[CONSTRAINT ] FOREIGN KEY 字段名 [,字段名2,…]

REFERENCES 主键列1 [,主键列2,…]

mysql> create table user_dep(

-> dep_id int(16) NOT NULL,

-> dep_name varchar(32) NOT NULL,

-> dep_location varchar(32) NOT NULL

-> );

Query OK, 0 rows affected (0.03 sec)

mysql>

mysql> alter table userinfo add user_dep varchar(32) not null;

mysql> alter table userinfo add constraint dep_id foreign key(dep_id) referencesuser_dep(dep_id);

唯一约束(UNIQUE KEY)

MySQL 唯一约束(Unique Key)是指所有记录中字段的值不能重复出现。例如,为 id 字段加上唯一性约束后,每条记录的 id 值都是唯一的,不能出现重复的情况。如果其中一条记录的 id 值为‘0001’,那么该表中就不能出现另一条记录的 id 值也为‘0001’。

唯一约束与主键约束相似的是它们都可以确保列的唯一性。不同的是,唯一约束在一个表中可有多个,并且设置唯一约束的列允许有空值,但是只能有一个空值。而主键约束在一个表中只能有一个,且不允许有空值。比如,在用户信息表中,为了避免表中用户名重名,可以把用户名设置为唯一约束。

在创建表时设置唯一约束

唯一约束可以在创建表时直接设置,通常设置在除了主键以外的其它列上。

在定义完列之后直接使用 UNIQUE 关键字指定唯一约束,语法格式如下:

UNIQUE

mysql> alter table userinfo add constraint user_name unique(user_name);

f0HuJQ8g0eEGmUAAAAASUVORK5CYII=

删除唯一性约束

mysql> alter table userinfo drop index user_name;

mysql默认值(default)

创建表时可以使用 DEFAULT 关键字设置默认值约束,具体的语法格式如下:

DEFAULT ;

mysql非空约束

MySQL 非空约束(NOT NULL)指字段的值不能为空。对于使用了非空约束的字段,如果用户在添加数据时没有指定值,数据库系统就会报错。可以通过 CREATE TABLE 或 ALTER TABLE 语句实现。在表中某个列的定义后加上关键字 NOT NULL 作为限定词,来约束该列的取值不能为空。

创建表时可以使用 NOT NULL 关键字设置非空约束,具体的语法格式如下:

NOT NULL;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值