日期:2014-05-16  浏览次数:20948 次

增补mysql的性能优化数条经验

1.只要一条数据时,使用limit 1,如果你确定你的条件下,只可能会有一条数据,请不要再让mysql继续下去查找下去

比较用例

1.1.select * from tablename where id = 1;

1.2.select 1 from tablename where id = 1 limit 1;

2.如果表中某一个字段经常被用来查询,那么请使用索引对该字段进行标记

alter table tablename and index(fieldone);

如此,查询的效率会增加很多。

3.在join 表的时候使用相当类型的列,并将其索引

如果你一个sql中使用较多的join查询,那么请确认两个表中的条件字段是否被建立索引,并且字段具有相当类型,比如说使用以下语句进行join链接

select * from table1 t1 left join table2 t2 on t1.name = t2.name;

那么请确认t1.name和t2.name具有相同类型的字符集,并且name在两个表中都有索引,那么这样的查询速度也会提升很多。

4.避免使用select *

如果你确定你将要获取表中某一些列,那么使用以下的查询

select field1 from table1?

而不是

select * from table1

因为越多的查询自然会增加数据库查询的压力,同时,从后台传输到前台两个独立的服务器时,也会增加网络传输的压力,那么请尽量使用需要什么字段就获取什么字段的好习惯。

5.我们应该为每张表设置一个自动增长的列,并且为主键,且字段类型为unsigned(未签字的),然后为auto_increment(自动增长的),并且请不要使用varchar类型的字段作为主键,即使是唯一的。

?

今天暂时先总结以上例子,稍后继续。