百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> mysql中key、primarykey、uniquekey与index区别详解
分享文章到:

mysql中key、primarykey、uniquekey与index区别详解

发布时间:09/01 来源:未知 浏览: 关键词:
一、key与primarykey区别;二、KEY与INDEX区别;三、mysql中UNIQUEKEY和PRIMARYKEY有什么区别... 一、key与primary key区别

CREATE TABLE wh_logrecord (
logrecord_id int(11) NOT NULL auto_increment,
user_name varchar(100) default NULL,
operation_time datetime default NULL,
logrecord_operation varchar(100) default NULL,
PRIMARY KEY (logrecord_id),
KEY wh_logrecord_user_name (user_name)
)

举荐:《mysql视频教程》

解析:

KEY wh_logrecord_user_name (user_name)

本表的user_name字段与wh_logrecord_user_name表user_name字段创立外键

括号外是创立外键的对应表,括号内是对应字段

相似还有 KEY user(userid)

固然,key未必都是外键

总结:

Key是索引束缚,对表中字段进行束缚索引的,都是通过primary foreign unique等新建的。常见有foreign key,外键关联用的。

KEY forum (status,type,displayorder) # 是多列索引(键)
KEY tid (tid) # 是单列索引(键)。

如建表时: KEY forum (status,type,displayorder)

select * from table group by status,type,displayorder 可否就主动用上了此索引,

而当 select * from table group by status 此索引实用吗?

key的用法:主如果用来加速查询速度的。

二、KEY与INDEX区别

批注:这局部我仍云里雾里。

KEY平常是INDEX同义词。要是关键字属性PRIMARY KEY在列定义中已给定,则PRIMARY KEY也可以只指定为KEY。这么做的目的是与其它数据库系统兼容。 PRIMARY KEY是一个独一KEY,此时,所有的关键字列必需定义为NOT NULL。要是这些列没有被明白地定义为NOT NULL,MySQL应隐含地定义这些列。一个表只要一个PRIMARY KEY。

MySQL 中Index 与Key 的区别

Key即键值,是关系模型理论中的一部份,比方有主键(Primary Key),外键(Foreign Key)等,用于数据完备性检否与独一性束缚等。而Index则处于实现层面,比方可以对表个的任意列创立索引,那么当创立索引的列处于SQL语句中的Where前提中时,就可以得到迅速的数据定位,从而迅速检索。至于Unique Index,则只是属于Index中的一种罢了,创立了Unique Index表示此列数据不成反复,猜想MySQL对Unique Index类型的索引可以做进一步特别优化吧。

于是乎,在设计表的时候,Key只是要处于模型层面的,而当需要进行查询优化,则对相干列创立索引即可。

别的,在MySQL中,关于一个Primary Key的列,MySQL已经主动对其创立了Unique Index,无需反复再在上面创立索引了。

搜寻到的一段解释:

Note that “primary” is called PRIMARY KEY not INDEX.
KEY is something on the logical level, describes your table and database design (i.e. enforces referential integrity…)
INDEX is something on the physical level, helps improve access time for table operations.
Behind every PK there is (usually) unique index created (automatically).

三、mysql中UNIQUE KEY和PRIMARY KEY有什么区别

1,Primary key的1个或多个列必需为NOT NULL,要是列为NULL,在添加PRIMARY KEY时,列主动更改为NOT NULL。而UNIQUE KEY 对列没有此请求

2,一个表只能有一个PRIMARY KEY,但可以有多个UNIQUE KEY

3,主键和独一键束缚是通过参照 索引实施的,要是插入的值均为NULL,则依据索引的道理,全NULL值不被记载在索引上,所以插入全NULL值时,可以有反复的,而其他的则不克不及插入反复值。

alter table t add constraint uk_t_1 unique (a,b);
insert into t (a ,b ) values (null,1);    # 不克不及反复
insert into t (a ,b ) values (null,null);#可以反复

四、运用UNIQUE KEY

CREATE TABLE `secure_vulnerability_warning` (
  `id` int(10) NOT NULL auto_increment,
  `date` date NOT NULL,
  `type` varchar(100) NOT NULL,
  `sub_type` varchar(100) NOT NULL,
  `domain_name` varchar(128) NOT NULL,
  `url` text NOT NULL,
  `parameters` text NOT NULL,
  `hash` varchar(100) NOT NULL,
  `deal` int(1) NOT NULL,
  `deal_date` date default NULL,
  `remark` text,
  `last_push_time` datetime default NULL,
  `push_times` int(11) default '1',
  `first_set_ok_time` datetime default NULL,
  `last_set_ok_time` datetime default NULL,
  PRIMARY KEY  (`id`),
  UNIQUE KEY `date` (`date`,`hash`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8

UNIQUE KEY的用法:主如果用来防止数据插入的时候反复的。

1,新建表时

CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
UNIQUE (Id_P)
)

要是需要命名 UNIQUE 束缚,以及为多个列定义 UNIQUE 束缚,请运用下面的 SQL 语法:

CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)
)

2,当表已被新建时,如需在 "Id_P" 列新建 UNIQUE 束缚,请运用以下 SQL:

ALTER TABLE Persons
ADD UNIQUE (Id_P)

如需命名 UNIQUE 束缚,并定义多个列的 UNIQUE 束缚,请运用下面的 SQL 语法:

ALTER TABLE Persons
ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)

3,撤销 UNIQUE 束缚

如需撤销 UNIQUE 束缚,请运用下面的 SQL:

ALTER TABLE Persons
DROP INDEX uc_PersonID

以上就是mysql中key 、primary key 、unique key 与index区别详解的细致内容,更多请关注 百分百源码网 其它相干文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有159人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板