MySQL语句优化的原则(2)

来源:我想网 时间:2009-10-27 12:09:00 

以下是我做的一个实验,可以发现索引能极大地提高查询的效率(我有一个会员信息表users,里边有37365条用户记录)

在不加索引的时候进行查询:

sql语句A:

select * from users where username like ‘%许%’;

在Mysql-Front中的8次查询时长为:1.40,0.54,0.54,0.54,0.53,0.55,0.54 共找到960条记录

sql语句B:

select * from users where username like ‘许%’;

在Mysql-Front中的8次查询时长为:0.53,0.53,0.53,0.54,0.53,0.53,0.54,0.54 共找到836条记录

sql语句C:

select * from users where username like ‘%许’;

在Mysql-Front中的8次查询时长为:0.51,0.51,0.52,0.52,0.51,0.51,0.52,0.51 共找到7条记录

为username列添加索引:

create index usernameindex on users(username(6));

再次查询:

sql语句A:

select * from users where username like ‘%许%’;

在Mysql-Front中的8次查询时长为:0.35,0.34,0.34,0.35,0.34,0.34,0.35,0.34 共找到960条记录

sql语句B:

select * from users where username like ‘许%’;

在Mysql-Front中的8次查询时长为:0.06,0.07,0.07,0.07,0.07,0.07,0.06,0.06 共找到836条记录

sql语句C:

select * from users where username like ‘%许’;

在Mysql-Front中的8次查询时长为:0.32,0.31,0.31,0.32,0.31,0.32,0.31,0.31 共找到7条记录

在实验过程中,我没有另开任何程序,以上的数据说明在单表查询中,建立索引的可以极大地提高查询速度。

另外要说的是如果建立了索引,对于like ‘许%’类型的查询,速度提升是最明显的。因此,我们在写sql语句的时候也尽量采用这种方式查询。

对于多表查询我们的优化原则是:

尽量将索引建立在:left join on/right join on … +条件,的条件语句中所涉及的字段上。多表查询比单表查询更能体现索引的优势。

11、索引的建立原则:

如果一列的中数据的前缀重复值很少,我们最好就只索引这个前缀。Mysql支持这种索引。我在上面用到的索引方法就是对username最左边的6个字符进行索引。索引越短,占用的 磁盘空间越少,在检索过程中花的时间也越少。这方法可以对最多左255个字符进行索引。

在很多场合,我们可以给建立多列数据建立索引。

索引应该建立在查询条件中进行比较的字段上,而不是建立在我们要找出来并且显示的字段上

12、一往情深问到的问题

IN、OR子句常会使用工作表,使索引失效。如果不产生大量重复值,可以考虑把子句拆开。拆开的子句中应该包含索引。

这句话怎么理解决,请举个例子

如下:

如果在fields1和fields2上同时建立了索引,fields1为主索引

以下sql会用到索引

select * from tablename1 where fields1=’value1′ and fields2=’value2′

以下sql不会用到索引

select * from tablename1 where fields1=’value1′ or fields2=’value2′

13.索引带来查询上的速度的大大提升,但索引也占用了额外的硬盘空间(当然现在一般硬盘空间不成问题),而且往表中插入新记录时索引也要随着更新这也需要一定时间.

有些表如果经常insert,而较少select,就不用加索引了.不然每次写入数据都要重新改写索引,花费时间; 这个视实际情况而定,通常情况下索引是必需的.

14.我在对查询效率有怀疑的时候,一般是直接用Mysql的Explain来跟踪查询情况.

你用Mysql-Front是通过时长来比较,我觉得如果从查询时扫描字段的次数来比较更精确一些.

标签:mysql,数据库优化,索引
0
投稿

猜你喜欢

  • SQL中位数函数实例

    2024-01-25 17:21:55
  • sql server如何去除数据中的一些无用的空格

    2024-01-18 02:22:22
  • 关于Flask项目无法使用公网IP访问的解决方式

    2021-01-03 10:04:00
  • python基础入门学习笔记(Python环境搭建)

    2022-01-12 20:27:48
  • Python flask路由间传递变量实例详解

    2021-03-13 16:30:16
  • XML和XSLT结合使网站设计浑然一体

    2008-09-05 17:13:00
  • Centos7下安装MySQL8.0.23的步骤(小白入门级别)

    2024-01-22 02:10:34
  • Python实现图的广度和深度优先路径搜索算法

    2021-09-14 23:50:19
  • python编写朴素贝叶斯用于文本分类

    2022-01-29 18:45:51
  • jQuery实现AJAX定时刷新局部页面实例

    2024-05-02 17:05:27
  • numpy.ndarray 实现对特定行或列取值

    2022-05-14 09:17:24
  • python 进程间数据共享multiProcess.Manger实现解析

    2021-03-25 14:06:53
  • Python字典查找数据的5个基础操作方法

    2021-09-08 23:19:45
  • MySQL 修改密码实例详解

    2024-01-27 05:36:28
  • vue基本使用--refs获取组件或元素的实例

    2024-05-02 16:35:20
  • 自学python的建议和周期预算

    2021-10-07 04:38:09
  • SQLServer 跨库查询实现方法

    2012-04-13 12:07:09
  • 基于Python实现傻瓜式GIF制作工具

    2023-03-13 18:39:44
  • JavaScript随机打乱数组顺序之随机洗牌算法

    2024-05-03 15:33:00
  • tensorflow之并行读入数据详解

    2021-09-20 14:42:30
  • asp之家 网络编程 m.aspxhome.com