位置: 编程技术 - 正文

MySQL索引之主键索引(mysql主键和索引)

编辑:rootadmin

推荐整理分享MySQL索引之主键索引(mysql主键和索引),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql 主索引,mysql索引建立原则,mysql索引建立原则,mysql创建主键索引的关键字使用,mysql索引建立原则,mysql 主索引,mysql主键索引和聚集索引,mysql创建主键索引的关键字使用,内容如对您有帮助,希望把文章链接给更多的朋友!

在MySQL里,主键索引和辅助索引分别是什么意思,有什么区别?上次的分享我们介绍了聚集索引和非聚集索引的区别,本次我们继续介绍主键索引和辅助索引的区别。

1、主键索引

主键索引,简称主键,原文是PRIMARY KEY,由一个或多个列组成,用于唯一性标识数据表中的某一条记录。一个表可以没有主键,但最多只能有一个主键,并且主键值不能包含NULL。

在MySQL中,InnoDB数据表的主键设计我们通常遵循几个原则:

1、采用一个没有业务用途的自增属性列作为主键;2、主键字段值总是不更新,只有新增或者删除两种操作;3、不选择会动态更新的类型,比如当前时间戳等。

这么做的好处有几点:

1、新增数据时,由于主键值是顺序增长的,innodb page发生分裂的概率降低了;可以参考以往的分享“[MySQL FAQ]系列 — 为什么InnoDB表要建议用自增列做主键”;2、业务数据有变更时,不修改主键值,物理存储位置发生变化的概率降低了,innodb page中产生碎片的概率也降低了。MyISAM表因为是堆组织表,主键类型设计方面就可以不用这么讲究了。

MySQL索引之主键索引(mysql主键和索引)

2、辅助索引

辅助索引,就是我们常规所指的索引,原文是SECONDARY KEY。辅助索引里还可以再分为唯一索引,非唯一索引。

唯一索引其实应该叫做唯一性约束,它的作用是避免一列或多列值存在重复,是一种约束性索引。

3、主键索引和辅助索引的区别

在MyISAM引擎中,唯一索引除了key值允许存在NULL外,其余的和主键索引没有本质性区别。也就是说,在MyISAM引擎中,不允许存在NULL值的唯一索引,本质上和主键索引是一回事。

而在InnoDB引擎中,主键索引和辅助索引的区别就很大了。主键索引会被选中作为聚集索引,而唯一索引和普通辅助索引间除了唯一性约束外,在存储上没本质区别。

从查询性能上来说,在MyISAM表中主键索引和不允许有NULL的唯一索引的查询性能是相当的,在InnoDB表通过唯一索引查询则需要多一次从辅助索引到主键索引的转换过程。InnoDB表基于普通索引的查找代价更高,因为每次检索到结果后,还需要至少再多检索一次才能确认是否还有更多符合条件的结果,主键索引和唯一索引就不需要这么做了。

经过测试,对万行数据的MyISAM做随机检索(整数类型),主键和唯一索引的效率基本一样,普通索引的检索效率则慢了%以上。换成InnoDB表的话,唯一索引比主键索引效率约慢9%,普通索引比主键索引约慢了%以上。

关于MySQL的方方面面大家想了解什么,可以直接留言回复,我会从中选择一些热门话题进行分享。 同时希望大家多多转发,多一些阅读量是老叶继续努力分享的绝佳助力,谢谢大家 :)

MySQL中Binary Log二进制日志文件的基本操作命令小结 MySQLBinaryLog也就是常说的bin-log,,是mysql执行改动产生的二进制日志文件,其主要作用有两个:*数据回复*主从数据库。用于slave端执行增删改,保持与master同

将MySQL查询结果按值排序的简要教程 MySQL查询结果如何排序呢?这是很多人都提过的问题,下面就教您如何对MySQL查询结果按某值排序,如果您感兴趣的话,不妨一看。之前有一个功能修改

MySQL的LEFT JOIN表连接的进阶学习教程 LEFTJOIN的主表这里所说的主表是指在连接查询里MySQL以哪个表为主进行查询。比如说在LEFTJOIN查询里,一般来说左表就是主表,但这只是经验之谈,很多

标签: mysql主键和索引

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

上一篇:MySQL索引之聚集索引介绍(sql建立聚集索引语句)

下一篇:MySQL中Binary Log二进制日志文件的基本操作命令小结(mysql binlog详解)

  • 建筑业无票支出
  • 物流公司车子
  • 进项税额可以不转出吗
  • 管理费用借贷方都有,如何结转
  • 税控盘未清卡怎么办
  • 缴纳税金属于什么会计分录
  • 上级工会返还的经费记什么收入
  • 年底向员工客户发放、赠送实物的怎么缴个税
  • 可供出售权益工具投资是非货币
  • 公告费交了以后能否撤销
  • 支付一年房租计入什么科目
  • 预付房租发票未到分录
  • 医院的固定资产是由财务负责的吗?
  • 红字通知单进项税额转出
  • 提前报废资产损失税前扣除
  • 企业所得税税前扣除异常
  • 物业服务合同印花算什么类型
  • 跨月冲红的发票怎么做账
  • 2021年个人开发票税率
  • 不管金税四期上线与否,税务严查一刻也没有放松!
  • 以前年度损益调整贷方余额表示什么
  • 预提工资的的计提依据
  • 房屋交易税费的计算
  • 清算时未分配利润为负数的处理方法是什么呢?
  • 银行承兑贴现到哪里去了
  • 租个人房屋办公怎么租
  • 企业所得税税率2.5% 5% 25%
  • 鸿蒙系统怎么开启开发者权限
  • 发票认证平台上不去
  • newdot.exe - newdot是什么进程 有什么用
  • 代开专用发票缴纳增值税需要计提吗?
  • 向灾区捐赠货物需要交增值税吗
  • 野生动物保护区有哪些
  • PHP:imagesetthickness()的用法_GD库图像处理函数
  • 企业收回应收账款会计分录
  • 购买财务软件报什么科目
  • 以前年度损益调整在利润表中怎么填
  • init 6命令
  • phpcms视频教程
  • 简单设置w11
  • 超市电子发票怎么开
  • 什么是技术服务工程师
  • wordpress site
  • python深拷贝与浅拷贝区别
  • mongodb好用吗
  • 一般纳税人和小规模纳税人怎么界定
  • 结转材料成本差异所需科目
  • 理财产品分红和收益比例
  • 物流公司扣押货物算犯法吗
  • 跨月的凭证出错如何处理
  • 更正会计差错的方法
  • 应付利息属于什么负债
  • 进项税加计抵减的分录怎么做?
  • 银行贷款利息支出税前扣除标准
  • 旅行社开的发票如何记账?
  • mysql根据时间查询最新一条数据
  • 数据库中经常用的函数
  • 安装并激活navicat
  • 包含正在使用的windows版本 无法格式化
  • 将程序桌面图标放到桌面
  • windows8关机在哪里
  • windowsxp服务在哪里
  • macbook imessage
  • centos如何安装yum
  • Linux操作系统网络及主机名配置
  • win8打游戏
  • 听歌播放失败什么意思
  • fedora update-grub
  • win7怎么设置工作组共享
  • [Unity3D]Stencil buffer失效了怎么办
  • shell脚本 -ne 0
  • jquery删除当前元素
  • Node.js中的事件循环是什么
  • 充分发挥党员的先锋模范作用,积极
  • 详解九章算法
  • php爬取网页数据
  • 为什么电子发票没有监制章
  • 重庆个人所得税是多少
  • 报纸的增值税税目是什么
  • 经营所得税怎么交
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设