mysql怎么加快搜索 mysql 搜索一条数据

mysql,有一张表里面已经有几千万条数据了,网页访问时极其缓慢,如何提高检索速度?一般查询的话应该有常用的语句的 。
比如常见查询为:
【mysql怎么加快搜索 mysql 搜索一条数据】select * from factdata where user='a' and module='b' and dtime between '2012-11-01 00:10:00' and '2012-11-01 00:11:10';
那么你这时候需要在factdata表上建立(user,module,dtime)的联合索引 。
alter table factdata add index i_merge(`user`,`module`,`dtime`);
你可以执行
explain select * from factdata where user='a' and module='b' and dtime between '2012-11-01 00:10:00' and '2012-11-01 00:11:10';
查看建立索引前面的返回的结果 。
假如没有索引的话,explain会显示返回查询全表的数据自然会很慢了 。
假如用到了索引的话,可以快速的找到需要查询的区间里的数据,往往需要查询的数据量是全表的1/100,1/1000 , 那么这时候花费的时间就是1/100,1/1000了 。
教你怎样在MySQL中提高全文搜索效率很多互联网应用程序都提供了全文搜索功能,用户可以使用一个词或者词语片断作为查询项目来定位匹配的记录 。在后台,这些程序使用在一个SELECT查询中的LIKE语句来执行这种查询,尽管这种方法可行 , 但对于全文查找而言,这是一种效率极端低下的方法,尤其在处理大量数据的时候 。
MYSQL如何降序排列?或如何加快降序查询的速度MySQL索引通常是被用于提高WHERE条件的数据行匹配或者执行联结操作时匹配其它表的数据行的搜索速度 。
MySQL也能利用索引来快速地执行ORDER BY和GROUP BY语句的排序和分组操作 。
通过索引优化来实现MySQL的ORDER BY语句优化:
1、ORDER BY的索引优化 。如果一个SQL语句形如:
SELECT [column1],[column2],…. FROM [TABLE] ORDER BY [sort];
在[sort]这个栏位上建立索引就可以实现利用索引进行order by 优化 。
2、WHERE + ORDER BY的索引优化 , 形如:
SELECT [column1],[column2],…. FROM [TABLE] WHERE [columnX] = [value] ORDER BY [sort];
建立一个联合索引(columnX,sort)来实现order by 优化 。
注意:如果columnX对应多个值 , 如下面语句就无法利用索引来实现order by的优化
SELECT [column1],[column2],…. FROM [TABLE] WHERE [columnX] IN ([value1],[value2],…) ORDER BY[sort];
3、WHERE+ 多个字段ORDER BY
SELECT * FROM [table] WHERE uid=1 ORDER x,y LIMIT 0,10;
建立索引(uid,x,y)实现order by的优化,比建立(x,y,uid)索引效果要好得多 。
MySQL Order By不能使用索引来优化排序的情况
* 对不同的索引键做 ORDER BY :(key1,key2分别建立索引)
SELECT * FROM t1 ORDER BY key1, key2;
* 在非连续的索引键部分上做 ORDER BY:(key_part1,key_part2建立联合索引;key2建立索引)
SELECT * FROM t1 WHERE key2=constant ORDER BY key_part2;
* 同时使用了 ASC 和 DESC:(key_part1,key_part2建立联合索引)
SELECT * FROM t1 ORDER BY key_part1 DESC, key_part2 ASC;
* 用于搜索记录的索引键和做 ORDER BY 的不是同一个:(key1,key2分别建立索引)
SELECT * FROM t1 WHERE key2=constant ORDER BY key1;
* 如果在WHERE和ORDER BY的栏位上应用表达式(函数)时,则无法利用索引来实现order by的优化
SELECT * FROM t1 ORDER BY YEAR(logindate) LIMIT 0,10;
特别提示:
1mysql一次查询只能使用一个索引 。如果要对多个字段使用索引,建立复合索引 。
2在ORDER BY操作中,MySQL只有在排序条件不是一个查询条件表达式的情况下才使用索引 。
本文来自CSDN博客,转载请标明出处:
如何写索引,让查询速度快首先来看看表是否有索引mysql怎么加快搜索的命令
show index from 表名;

推荐阅读