位置: 编程技术 - 正文

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详解)

  • 城建税和教育费附加
  • 摊薄净资产收益率是什么意思
  • 递延所得税负债怎么算
  • 企业清算所得税申报
  • 股权转让和变更法人一样吗?
  • 金税四期一般纳税人应对
  • 飞机票的快递费多少钱
  • 增值税发票选择确认平台勾选注意事项
  • 记账凭证按其适用的交易和事项分类可以分为
  • 已抵扣进项怎么转出
  • 多缴纳的税款不退税怎么入账
  • 上年的应收帐款在本年度如何录入?
  • 房地产开发资质管理办法
  • 委托贷款利息收入账务处理
  • 财务发票已开但钱未到位怎么处理?
  • 上海市购销合同印花税计税金额怎么算?
  • 增值税暂估
  • 旅游业是一个怎样的产业
  • 劳务派遣实缴资本
  • 本年利润结转到利润分配是每月都结转还是年底结转
  • 研发费用入账
  • 委托代销中受托方账务处理
  • 新公司税控盘购买流程
  • 其他应付款辅助核算怎么挂
  • configureandwatch
  • 内账进项税不设置怎么账务处理
  • 会计分录是怎么写的
  • 收到培训内容的英文
  • 去年的成本发票怎么做账
  • php语言之面向对象编程 educoder
  • 建筑公司结算会计
  • 车保险理赔的钱多久到账
  • three.js入门指南
  • 技术维护费计入
  • vue经典案例
  • php上传图片到数据库完整代码
  • 企业持有待售的固定资产,应当对其预计
  • vue中的路由参数如何获取
  • Js中操作数组的方法
  • 固定资产投资账面价值
  • 土地增值税成本费用
  • 什么是记账凭证账务处理程序
  • 发工资扣了社保可以要求退回吗
  • 补交以前年度环保税会计分录
  • 个体经营部能抵扣个税吗
  • 房屋租赁如何入账
  • sql server数据库异地备份
  • 固定资产未入账的定性依据
  • 本月购进原材料取得增值税专用发票
  • 固定资产盘点盘什么
  • 发票金额大于实际报销怎么做账
  • 公司支付宝账户提现需要手续费吗
  • 非营利性代收代缴税款
  • 用友关账怎么取消
  • 其他综合收益相反科目
  • 基金会对外捐赠,对方开什么发票
  • 货物发出退货
  • 流动比率怎么算出来的
  • window系统怎么查看
  • WIN10系统硬盘设置
  • fedora系统安装教程
  • Windows Server AD 访问数量控制配置方法
  • windows有哪些
  • 磁盘清理win10
  • windows10周年更新
  • win8系统如何关闭防火墙
  • css中dl
  • perl中use的用法
  • opengl基础知识噪声名词解释
  • table标签怎么设置宽高
  • jquery插件怎么用到自己的网站
  • npm安装淘宝镜像操作方式
  • unity3d跨平台
  • jQuery实现的指纹扫描效果实例(附演示与demo源码下载)
  • python如何用
  • javascript default
  • 公司税务电子发票怎么开
  • 电子税务局如何查询财务报表
  • 电信宽带欠费滞纳金最多减免多少?
  • 杭州国税电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设