位置: 编程技术 - 正文

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

编辑:rootadmin

推荐整理分享mysql中key 、primary key 、unique key 与index区别,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

mysql中索引是非常重要的知识点,相比其他的知识点,索引更难掌握,并且mysql中的索引种类也有很多,比如primary key 、unique key 与index等等,本文章向大家介绍mysql中key 、primary key 、unique key 与index区别。

一、key与primary key区别

解析:

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中key 、primary key 、unique key 与index区别

另外,在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值时,可以有重复的,而其他的则不能插入重复值。

四、使用UNIQUE KEY

UNIQUE KEY的用途:主要是用来防止数据插入的时候重复的。

1,创建表时

如果需要命名 UNIQUE 约束,以及为多个列定义 UNIQUE 约束,请使用下面的 SQL 语法:

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

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

mysql alter table命令修改表结构实例 mysql实例之使用altertable命令修改表结构mysqlaltertable语句可以修改表的基本结构,例如添加字段、删除字段、添加主键、添加索引、修改字段数据类型、

mysql alter table修改表命令整理 MYSQLALTERTABLE命令用于修改表结构,例如添加/修改/删除字段、索引、主键等等,本文章通过实例向大家介绍MYSQLALTERTABLE语句的使用方法,MySQLALTER语法如

mysql批量执行sql文件的方法 1、待执行的sql文件为1.sql、2.sql、3.sql、4.sql等2、写一个batch.sql文件:source1.sql;source2.sql;source3.sql;source4.sql;3、在mysql下执行source/batch文件所在目录/batch.sql

标签: mysql中key 、primary key 、unique key 与index区别

本文链接地址:https://www.jiuchutong.com/biancheng/348893.html 转载请保留说明!

上一篇:mysql 复制表结构和数据实例代码(mysql 复制表结构并把满足条件的数据添加到新表)

下一篇:mysql alter table命令修改表结构实例

  • 个人购买二手房贷款能贷多少
  • 利税总额计算公式利润表怎么计算
  • 甲企业持有乙企业的非上市股票2000股
  • 改革性补贴是否属于规范的津贴补贴
  • 先报个税还是先报增值税,有影响吗?
  • 公司与公司之间借款需要交税吗
  • 本月进项税大于销项税有留底,如何做会计分录
  • 房产税的原值是如何确定的
  • 累计折旧和固定资产减值准备的区别
  • 受托开发软件产品免征增值税
  • 建筑面积包括分摊建筑面积吗
  • 固定资产采用工作量法计提折旧怎么算
  • 公司土地和厂房可以按折价卖结股东权益吗
  • 品质问题扣供应商款
  • 建安企业增值税税负是多少
  • 预付材料款的会计分录怎么写
  • 固定资产增值税可以一次性抵扣吗
  • 预收物业费是否必须开具发票
  • 本月出口下月开发票可以吗
  • 加油费开的专用发票可以用来抵扣企业所得税吗
  • 接手新公司涉税问题分析
  • 收到发票,未付款,付款的时候需要把发票复印做附件吗
  • 进项票小于销项票怎么办
  • 食用盐的增值税是多少
  • 建安行业简易计税可以抵扣吗
  • 办理环评费用
  • 运输发票车种车号要求 自有车
  • 单位外汇账户可分为
  • 财产行为税税种
  • 举办活动购买的东西会计分录
  • 营改增后房地产会计账务处理
  • 什么叫做材料成型工艺
  • win10电源已接通未充电怎么办
  • php unset()
  • csinsmnt.exe进程的作用介绍 csinsmnt是什么进程
  • 购买商品房交税流程
  • 被税怎么办
  • 什么情况下增长率是0
  • 朱顶雀的饲养
  • 个体户跟企业户
  • 框架导入
  • 解决城市内涝的题目
  • php中自定义函数的语法格式
  • vue3定义全局变量
  • php封装app
  • 发票金额和打款金额不一致怎么办
  • 认证发票可以分两次进行吗
  • 现金流量表本月数和本年累计数是相等的么
  • 私车公用维修费用谁出
  • 金蝶余额调节表勾对日期什么意思
  • 公司的资金管理模式是什么?
  • 残保金会计分录人员经费
  • 疫情期间减免的养老保险算工龄吗
  • 出口退税会计处理流程
  • 职工教育经费产生的差异
  • 决算清理期和库款报解整理期
  • 应付职工薪酬的工资是实发工资还是应发工资
  • 应收账款收不回来怎么处理比较好
  • 增值税红字冲销能跨年吗
  • 公司基本账户提现规定
  • mysql 序列化转数组
  • mac搜索app
  • centos怎么查看文件
  • wmiprvse.exe是什么程序
  • 电脑xp桌面
  • nerosmartstart.exe - nerosmartstart是什么进程 作用是什么
  • 怎么让微软账户获得所有权限
  • win10外置光驱读不出光盘怎么办
  • linux限制用户cpu使用
  • javascript标准
  • EXTjs4.0的store的findRecord的BUG演示代码
  • Fast TileMap
  • js计算字符串长度 汉字长度
  • unity unite
  • android 数据
  • 免征的增值税税额应计入营业外收入嘛
  • 汽车购车发票开完票能更改名字吗?
  • 山东省合格考密码
  • 国网福建电力微信公众
  • 税审工作流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设