`
zccst
  • 浏览: 3319106 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

mysql中key 、primary key 、unique key 与index区别

阅读更多
作者:zccst

一、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)
)
解析:
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:
MySQL:

ALTER TABLE Persons
DROP INDEX uc_PersonID





如果您觉得本文的内容对您的学习有所帮助,您可以微信:


  • 大小: 28.9 KB
分享到:
评论
4 楼 DEMONU 2016-11-08  
谢谢,虽然不能给你赞助,但是要给你顶
3 楼 21glove 2015-01-08  
非常不错的文章
2 楼 di1984HIT 2014-07-16  
xiede henhao
1 楼 yql 2012-11-15  

相关推荐

    MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别

    总的来说,理解 PRIMARY KEY、UNIQUE KEY 和 INDEX 的区别,以及如何适当地在数据库设计中使用它们,对于优化数据库性能和保证数据完整性至关重要。在创建索引时,应考虑查询模式、存储需求和性能平衡,确保数据库在...

    Mysql中key和index的区别点整理

    在MySQL中,常见的索引类型包括普通索引(INDEX)、主键索引(PRIMARY KEY)、唯一索引(UNIQUE INDEX)、联合索引(多个列的索引)和全文索引(FULLTEXT INDEX)。 `key`(键)则是数据库中用于确保数据完整性的...

    mysql unique key在查询中的使用与相关问题

    1、建表语句: CREATE TABLE `employees` ( `emp_no` int(11) NOT NULL, `birth_date` date NOT NULL, `first_name` varchar(14) NOT NULL, ... UNIQUE KEY `idxunique_first_name_gender` (`first_name`

    SQL UNIQUE 约束

    UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。 PRIMARY KEY 约束拥有自动定义的 UNIQUE 约束。 请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。 CREATE TABLE 时...

    presto sql 与mysql sql 对比.pdf

    Presto SQL 与 MySQL SQL 对比 基础 Presto SQL 和 MySQL SQL 都是关系型数据库管理系统,但它们之间存在一些差异。在 Presto SQL 中,字段名和表名使用双引号括起来,而在 MySQL SQL 中,字段名和表名使用反引号...

    MySQL中文参考手册

    - **创建索引**:INDEX、UNIQUE INDEX或PRIMARY KEY用于提高查询性能。 - **删除索引**:DROP INDEX语句。 8. **视图** - **创建视图**:CREATE VIEW语句,虚拟表,基于查询结果。 - **修改视图**:ALTER VIEW...

    MySQL使用UNIQUE实现数据不重复插入

    UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。 PRIMARY KEY 拥有自动定义的 UNIQUE 约束。 请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。 下面的 SQL 在 ...

    头歌MySQL数据库实训答案有目录.pdf

    约束是用于限制数据的输入的规则,MySQL 中常用的约束有 PRIMARY KEY、FOREIGN KEY、UNIQUE、CHECK 等。 * 主键约束(PRIMARY KEY):用于指定表中的唯一标识符,例如 `CREATE TABLE t_user1(userId INT PRIMARY ...

    国开作业《MySQL数据库应用》实验训练1在MySQL中创建数据库和表参考107.pdf

    在IT领域,数据库是存储和管理数据的核心工具,而MySQL是一种广泛应用的关系型数据库管理系统(RDBMS),尤其在互联网行业中,由于其开源、免费、高效和稳定的特点,被广泛用于网站开发、数据分析以及各种业务系统。...

    Mysql中Insert into xxx on duplicate key update问题

    ON DUPLICATE KEY UPDATE` 是一个非常实用的特性,它允许你在尝试插入新记录时,如果插入的数据违反了唯一性约束(如UNIQUE索引或PRIMARY KEY),则自动更新已经存在的匹配行,而不是抛出错误。这个特性是MySQL特有...

    ORACLE、MySQL、SqlServer,三大数据库区别整理以及常用语句

    **与PRIMARY KEY的区别**: - 每个表可以有多个UNIQUE约束。 - 每个表只能有一个PRIMARY KEY约束。 - PRIMARY KEY约束也自动具有UNIQUE属性,但它还增加了自动索引和不允许NULL值的特点。 **创建UNIQUE约束的方法**...

    mysql8中文参考手册.rar

    5. **约束**:理解主键(PRIMARY KEY)、唯一键(UNIQUE)、外键(FOREIGN KEY)和默认值(DEFAULT)的概念及其在数据完整性中的作用。 6. **视图**:学习创建和使用视图,这有助于简化复杂的查询并提供数据安全。 ...

    【EXPLAIN】“type”字段详解之MySQL官方文档翻译

    - **应用**: 当将 PRIMARY KEY 或 UNIQUE 索引与常量值匹配时使用。例如: - `SELECT * FROM tbl_name WHERE primary_key = 1;` - `SELECT * FROM tbl_name WHERE primary_key_part1 = 1 AND primary_key_part2 = 2...

    mysql第三阶段

    4. 添加唯一约束:ALTER TABLE `tb_name` ADD [CONSTRAINT [symbol]] UNIQUE [INDEX | KEY] [index_name] [index_type] (index_col_name,...); 5. 添加外键约束:ALTER TABLE `tb_name` ADD [CONSTRAINT [symbol]] ...

    mysql中创建各种索引的语句整理知识.pdf

    在 MySQL 中,添加 PRIMARY KEY 索引的语句为: ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 其中,`table_name` 是要添加索引的表名,`column` 是要作为主键的列名。例如: ALTER TABLE `jifen_...

    mysql 中文及英文参考手册

    - 主键(Primary Key):唯一标识表中每一行的字段,不允许有重复值。 2. **SQL基础** - SELECT:用于从数据库中选取数据。 - INSERT:向表中插入新的记录。 - UPDATE:更新表中已存在的记录。 - DELETE:删除...

Global site tag (gtag.js) - Google Analytics