位置: 编程技术 - 正文

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

  • 个人所得税本期收入是扣完保险吗
  • 设在西部地区的鼓励类产业企业减按15%怎么填
  • 没有上市的公司怎么看财务报表
  • 普票为啥不能抵扣
  • 个税申报赡养老人可以填公婆吗
  • 发票备注没写
  • 标准成本法核算方法
  • 增值税专用发票可以开电子发票吗
  • 劳动竞赛费用在什么科目列支做会计分录?
  • 物流 贷款
  • 进项税认证怎么做分录
  • 医院减免医药费后还可以报保险吗
  • 第一季度盈利第二季度亏损全年盈利
  • 积累与消费比例怎么计算
  • 农产品收购发票图片
  • 预收物业费是否必须开具发票
  • 蔬菜批发公司销售蔬菜是否免税
  • 运输发票交印花税吗
  • 全国失信人员信息
  • 增值税勾选平台在哪里
  • 固定资产投资方案
  • 企业所得税零申报资产总额怎么填
  • 项目资本金入账
  • 产值等于营业额吗
  • 注册资本认缴与注册登记实操
  • 优酷路由宝是什么东西
  • 然后重装系统win7
  • Yii2使用驼峰命名的形式访问控制器(实例讲解)
  • 应税消费品对外出售
  • elementui常用组件
  • 销售额是否含税?
  • nginx配置tp5
  • [ChatGPT] 从 GPT-3.5 到 GPT-5 的进化之路 | ChatGPT和程序员 : 协作 or 取代
  • 腾讯一面问什么
  • 特斯拉 ai day
  • aida理论包括哪些内容?
  • python快速检索
  • 返还土地出让金违法吗?
  • 织梦收费5800的解决方法
  • 公对公二手车交易税
  • SQLite教程(十二):锁和并发控制详解
  • 深入理解jvm第三版pdf百度云
  • 电子承兑汇票的承兑人是谁
  • 期初库存和期末库存可以修改吗
  • 计提租金如何做账务处理
  • 营业税金及附加怎么计算
  • 社保稳岗补贴账务处理分录
  • 退货属于什么物流
  • 广告费用收入
  • 维修费收入怎么结转销售成本
  • 仓库货架应该计入什么科目
  • 应付票据含税吗
  • imessage对方看了会显示已读吗
  • win7安装sqlserver2000
  • win10分辨率2560*1080
  • 一岁的宝宝可以喝枸杞水吗
  • coocareservice.exe是病毒吗
  • Linux /bin, /sbin, /usr/bin, /usr/sbin 区别
  • centos7取消挂载硬盘
  • win8更改账户
  • win8.1怎么关闭防火墙
  • win8飞行模式在哪
  • Android的AsyncTask官方API谷歌翻译版
  • 绝对给力的超经典
  • javascript要怎么学
  • node js 开发
  • jQuery Ajax传值到Servlet出现乱码问题的解决方法
  • node.js 定时任务
  • unity的vs
  • android菜鸟教程
  • python中如何抛出异常
  • 电子税务局 安徽
  • 河南电子税务局开票流程
  • 卖废铁分录
  • 广西壮族自治区图书馆
  • 深圳12366接听客服工作怎么样
  • 在山东省一个月水费大概多少
  • 出口报价必须含增值税吗
  • 广东省国家税务总局稽查局局长
  • 云南4050人员2020最新政策
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设