我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL与PHP的基础与应用专题之索引

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL与PHP的基础与应用专题之索引

概述

从今天开始, 小白我将带领大家一起来补充一下 数据库的知识.

索引

索引 (Index) 是一种特殊的数据结构, 类似于图书的目录. 索引能够极大的提升数据库的查询效率. 如果没有索引, 在查询数据时必须扫描表中的说有记录才能找出符合条件的记录, 这种全表扫描的查询效率非常低.

索引的种类描述
普通索引最基本的索引, 没有任何限制, 仅加速查询
唯一索引索引列的值必须唯一, 但允许有空值
主键索引一种特殊的唯一索引, 不允许有空值
复合索引两个或多个列上的索引被称作符合索引
全文索引对文本内容进行分词索引

格式:

CREATE INDEX 索引名 ON 表名(列名)

查询分析器 EXPLAIN

EXPLAIN 命令可以查看 SQL 语句的执行计划. 当 EXPLAIN 与 SQL 语句一起使用时, MySQL 将显示来自优化器的有关语句执行计划的信息. MySQL 解释了它将如何处理语句, 包括有关如何连接表以及以何种顺序连接表的信息.

查询分析器的用途:

  • 分析出表的读取顺序
  • 数据读取操作的操作类型
  • 哪些索引可以使用
  • 哪些索引被实际使用
  • 表之间的引用
  • 每张表有多少行被优化器查询

结果解析:

参数描述
id执行 SELECT 或操作表的顺序
select_type查询的类型, 如 SIMPLE, PRIMARY, SUBQUERY, DERIVED, UNION 等
table当前行使用的表名
partitions匹配的分区
type连接类型
possibile_keys可能使用的索引
key实际使用的索引, NULL 表示未使用索引
key_len查询中使用的索引长度
ref列与索引的比较
rows扫描的行数
filtered选取的行数占扫描的行数的百分比
extra其他信息

格式:

EXPLAIN SQL 语句

例子:

MySQL 日志

日志 (Log) 用于记录数据库的运行情况, 以及用户对数据库执行的各类操作. 当数据库发生故障时, 可以根据日志分析和解决问题, 从而对数据进行恢复.

日志描述
重做日志 (Redo Log)重做日志是一种物理格式的日志, 记录的是物理数据页面修改的信息
回滚日志 (Undo Log)回滚日志是一种逻辑格式的日志, 在执行 Undo 的时候. 仅仅是将数据从逻辑上恢复至事务之前的状态
二进制日志 (Bin Log)二进制日志是一种逻辑格式的日志, 以二进制文件的形式记录了数据库中的操作, 但不记录查询语句
错误日志 (Error Log)错误日志记录着 Mysqld 启动和停止, 以及服务器在运行过程中发生的错误的关信息
慢查询日志 (Slow Query Log)慢查询日志记录执行时间过长和没有使用索引的查询语句
一般查询日志 (General Log)记录了服务器收到的每一个查询或是命令, 无论这些查询是命令是否正确甚至是否包含语法错误
中继日志 (Relay Log)中级日志类似二进制, 可用于复制架构中, 使从服务器和主服务器的数据保持一致

慢查询日志

慢查询日志用于记录 MySQL 数据库中响应时间超过指定阈值的语句. 慢查询日志通常也被称为慢体质, 因为慢查询不仅仅针对 SELECT 语句, 像 INSERT, UPDATE, DELETE 等语句. 只要响应时间超过所设定阈值都会记录在慢查询日志中.

参数描述
slow_query_log是否开启慢查询日志, 1 表示开启, 0 表示关闭
slow_query_log_file慢查询日志存储路径, 可选
long_query_time阈值, 当 SQL 语句的响应时间超过阈值就会被记录到日志中
log_queries_ not_using_indexes未使用索引的查询也被记录到慢查询中, 可选
log_output日志存储方式, 默认为 FILE
log_output=‘FILE’ 表示将日志存入文件
log_output=‘TBALE’ 表示将日志存入数据库
log_output=‘FILE, TABLE’ 表示同时将日志存入文件和数据库

开启慢查询:

set slow_query_log='ON';
set long_query_time=1;

到此这篇关于MySQL与PHP的基础与应用专题之索引的文章就介绍到这了,更多相关MySQL 索引内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL与PHP的基础与应用专题之索引

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

PHP与MySQL索引的常见问题及解决方法

引言:在使用PHP开发网站应用程序时,经常会涉及到与数据库的交互操作,而MySQL作为开发者最常用的数据库之一,索引的优化对于提高查询效率起着至关重要的作用。本文将介绍PHP与MySQL索引的常见问题,并给出相应的解决方法,同时提供具体的代
2023-10-21

RiSearch PHP 如何应对分布式环境下的搜索与索引问题

随着互联网的迅猛发展,数据量急剧增长,搜索引擎成为了人们获取信息的主要途径之一。而在分布式环境下,搜索和索引问题变得更加复杂。RiSearch是一款强大的PHP搜索引擎库,它提供了完善的解决方案,帮助开发者应对分布式环境下的搜索与索引问题。
2023-10-21

MySQL中unique索引的使用技巧与常见问题解答

MySQL中unique索引的使用技巧与常见问题解答MySQL是一种流行的关系型数据库管理系统,在实际应用中,唯一索引(unique index)在数据表设计中起着至关重要的作用。唯一索引能够确保表中某一列的数值唯一,避免出现重复数据。本
MySQL中unique索引的使用技巧与常见问题解答
2024-03-15

如何利用索引提升PHP与MySQL的分页查询效率?

简介:在使用PHP与MySQL进行分页查询时,为了提高查询效率,可以利用数据库索引来加速查询操作。本文将介绍如何正确创建索引以及如何在PHP代码中进行分页查询。一、什么是索引索引是数据库中一种特殊的数据结构,它可以帮助数据库系统快速定位到存
2023-10-21

如何利用索引提升PHP与MySQL的排序和分组操作?

索引是一种在数据库表中创建的数据结构,用来提高查询操作的效率。在PHP和MySQL中,索引可以在排序和分组操作中发挥重要作用,提升数据库查询的性能。本文将介绍如何利用索引来优化PHP与MySQL的排序和分组操作,并提供具体的代码示例。排序操
2023-10-21

MySQL基础教程13 —— 函数之与GROUP BY子句同时使用的函数

1. GROUP BY(聚合)函数 本章论述了用于一组数值操作的 group (集合)函数。除非另作说明, group 函数会忽略 NULL 值。 假如你在一个不包含 ROUP BY子句的语句中使用一个 group函数 ,它相当于对所有行进
2022-05-17

探索Unity3D游戏引擎,开启游戏开发之旅(Unity3D游戏引擎在游戏开发中的应用与探索)

Unity3D是一款跨平台游戏引擎,广泛应用于各类游戏开发,包括3D、2D、移动、VR和AR游戏。其优势在于跨平台支持、强大的图形渲染、物理引擎、友好的用户界面和丰富的工具集。探索Unity3D可通过在线教程、官方文档、社区论坛、资产商店和创建游戏原型等方式,帮助开发人员深入了解引擎的工作原理并将其应用于游戏开发中。
探索Unity3D游戏引擎,开启游戏开发之旅(Unity3D游戏引擎在游戏开发中的应用与探索)
2024-04-02

编程热搜

目录