位置: 编程技术 - 正文

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

编辑:rootadmin

推荐整理分享MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别,希望有所帮助,仅作参考,欢迎阅读内容。

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

对于题目中提出的问题,可以拆分来一步步解决。在 MySQL 中 KEY 和 INDEX 是同义。那这个问题就可以简化为 PRIMARY KEY,UNIQUE KEY 和 INDEX 的区别。而这三者也正好是索引的划分,主键索引,唯一索引和普通索引(INDEX)。

使用 INDEX 来加速从数据库中读取数据。INDEX 通常加在那些 JOIN, WHERE,和 ORDER BY 子句的列上。

创建索引时,需要确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE 子句的条件)。 实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。

索引也有它的缺点:虽然索引提高了查询速度,却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。

MySQL 中 KEY 与 INDEX 区别

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

KEY 即键值,是关系模型理论中的一部份,比如有主键(PRIMARY KEY),外键(Foreign KEY)等,用于数据完整性检否与唯一性约束等。而 INDEX 则处于实现层面,比如可以对表个的任意列建立索引,那么当建立索引的列处于SQL语句中的Where条件中时,就可以得到快速的数据定位,从而快速检索。至于UNIQUE INDEX,则只是属于INDEX中的一种而已,建立了UNIQUE INDEX表示此列数据不可重复,猜想MySQL对UNIQUE INDEX类型的索引可以做进一步特殊优化吧。

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

KEY

KEY 是数据库的物理结构,包含两层含义,一是约束,偏重于约束和规范数据库的结构完整性,二是索引,辅助查询。&#;primary key 有两个作用,一是约束作用(constraint),用来规范一个存储主键和唯一性,但同时也在此key上建立了一个index;&#;unique key 也有两个作用,一是约束作用(constraint),规范数据的唯一性,但同时也在这个key上建立了一个index;&#;foreign key也有两个作用,一是约束作用(constraint),规范数据的引用完整性,但同时也在这个key上建立了一个index;

可见,key是同时具有constraint和index的意义.

INDEX

INDEX 也是数据库的物理结构,但他只有辅助查询作用,它会在创建时占用另外的空间。索引分为前缀索引、全文索引等。索引只是索引,不会去约束索引字段的行为。

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

PRIMARY KEY 和 UNIQUE KEY 的区别

PRIMARY KEYs(主键) 和 UNIQUE KEYs(唯一键约束) 是类似的, PRIMARY KEY通常是一列,也有可能多列,通常由他来决定一行数据(row)。 一张表只能有一个 PRIMARY KEY,但可以有很多 UNIQUE KEY。 当给一列设置为 UNIQUE KEY 之后,不能有两行在该列上有相同的数据。 PRIMARY KEY 不允许有 NULL值,但是 UNIQUE KEY 可以。

修改表 `ALTER TABLE table_name ADD PRIMARY KEY(column_name, …)

总结,相同点:&#;PRIMARY KEY 和 UNIQUE KEY 都是用来保证列上数据的为原型&#;都可以在一列或者多列上加

差异点:&#;同一张表 PRIMARY KEY 只能有一个, UNIQUE KEY可以有多个&#;PRIMARY KEY 不能有空值, UNIQUE KEY 可以有。如果 PRIMARY KEY 的1个或多个列为NULL,在增加PRIMARY KEY时,列自动更改为 NOT NULL 。而UNIQUE KEY 对列没有要求是通过参考索引实施的,如果插入的值均为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);#可以重复

在MySQL中,对于一个PRIMARY KEY的列,MySQL已经自动对其建立了UNIQUE INDEX,无需重复再在上面建立索引了。

网上关于 PRIMARY KEY 和 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).

操作索引

建立索引会占用磁盘空间的索引文件。CREATE INDEX IndexName ON mytable(username(length));

如果是 CHAR,VARCHAR 类型,length 可以小于字段实际长度;如果是 BLOB 和 TEXT类型,必须指定 length。

在创建表时创建索引:

删除索引

DROP INDEX [INDEXName] ON mytable;

MySQL 4G内存服务器配置优化 公司网站访问量越来越大(日均超万PV),MySQL自然成为瓶颈,关于MySQL的优化,最基本的是MySQL系统参数的优化。MySQL对于web架构性能的影响最大,也

Mysql 5.7. winx ZIP Archive 安装及使用过程问题小结 今天学着安装了MySQL,过程出现了一些问题,查看几个相关文章后解决了,记录下来供大家参考。1.下载

mysql server is running with the --skip-grant-tables option TheMySQLserverisrunningwiththe--skip-grant-tablesoptionsoitcannotexecutethisstatement意思貌似MYSQL还运行在--skip-grant-tables模式,如何让他回到原来的模式第一种方法:原来

标签: MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别

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

上一篇:Windows安装MySQL 5.7.18 解压版的教程(windows安装mysql5.7详细步骤)

下一篇:MySQL 4G内存服务器配置优化(mysql内存占用一直增高不释放)

  • 收取承包费如何交税
  • 如何办理车辆购置置换补贴手续
  • 政府转让土地使用权
  • 个体工商户2023年税收政策
  • 企业所得税季报可以更正吗
  • 开了负数发票增值税申报表怎么填
  • 增值税如何减税
  • 短期筹资方式有没有股票
  • 印花税缴款了发现报错了怎么办?
  • 工程违约金收入如何入账
  • 拆除固定资产的补偿款
  • 发票上有个含税金额什么意思?
  • 建筑劳务分包一般纳税人可以选择简易计税法吗?
  • 物业公司小规模纳税人如何报税
  • 有效期起止时间段与已有备案有效期有交集
  • 季初从业人数和季末从业人数怎么填
  • 销售不动产预收款纳税义务发生时间
  • 一次性收取的租金怎么纳税
  • 出口货物应退税额确认的会计分录
  • 高新企业研发项目
  • 苹果mac切换桌面快捷键
  • Windows10如何切换中英文输入法
  • win7系统中英文切换快捷键
  • win10取消登陆密码
  • 如何打印word文档手机上
  • 溢价购入债权投资是为啥
  • 金税四期查到了怎么办
  • 固定资产报废怎么处理
  • RPDFLchr.exe - RPDFLchr是什么进程 有什么用
  • rosnmgr.exe - rosnmgr是什么进程 有什么用
  • 出口零退税率商品有哪些
  • 对于在某一时点履行义务,企业应当在
  • 保险储金是什么意思
  • 今日立冬祝福语大全
  • 外购产品会计分录
  • 公司租房子 房东让我们代缴税
  • 编译安装php8
  • 企业内部转账通知单
  • 前端如何将项目分类
  • pytorch卷积操作
  • 应交税费转出会计分录
  • 固定资产处置营业外支出
  • phpcms 1064错误的解决办法
  • 帝国cms8.0
  • 土地利息可以作为土增扣除吗
  • 工程项目怎么挣钱
  • 企业收到投资款应贷记什么账户
  • 消费税的计税方式有哪几种?
  • 报销金额比发票金额少可以吗
  • 合同约定合同期限自动顺延
  • 公司按最低标准交社保可以申请补偿吗
  • 既有从价又有从租如何计算房产税
  • 管理费用和营业费用的比例
  • 贷记坏账准备借记什么
  • 高速公路过路费增值税
  • 发票 发票专用章
  • 影响固定资产折旧的基本因素不包括
  • windowsserver2008r2standard激活
  • winxp如何删除网卡驱动
  • linux sed
  • 开始菜单里没有设置选项
  • android真机调试解析包错误
  • perl语言基本命令
  • 批处理自动关闭
  • 只指定行网络什么意思
  • windows下使用什么命令查看监听端口
  • javascript 操作css
  • arp欺骗防范方法
  • python 数据结构 算法
  • android network
  • unity3d Human skin real time rendering with blood and water drop effect真实模拟人皮实时渲染之血液和水珠掉落效果
  • python中元祖的用法
  • 谈谈我对环境保护的认识
  • flask框架官方文档
  • 国家税务总局增值税发票查验平台网址
  • 第三方审计报告需要多久
  • 国税局登录密码修改
  • 出口退税的企业货币要回国内吗
  • 关于进一步加强工作纪律改进工作作风的通知
  • 商住两用房出售要交契税吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设