sql优化:
- 只返回需要的数据
a) 不要写SELECT *的语句
b) 合理写WHERE子句,不要写没有WHERE的SQL语句。
- 尽量少做重复的工作
使用join代替子查询
- 适当建立索引(不是越多越好)但以下几点会进行全表扫描
a) 左模糊查询’%…’
b) 使用了不等操作符!=
c) Or使用不当,or两边都必须有索引才行
d) In 、not in
e) Where子句对字段进行表达式操作
f) 对于创建的复合索引(从最左边开始组合),查询条件用到的列必须从左边开始不能间隔。否则无效,复合索引的结构与电话簿类似
g) 全文索引:当于对文件建立了一个以词库为目录的索引(文件大全文索引比模糊匹配效果好)
索引优化
一、 创建索引,以下情况不适合建立索引
l 表记录太少
l 经常插入、删除、修改的表
l 数据重复且分布平均的表字段
二、 复合索引
如果一个表中的数据在查询时有多个字段总是同时出现则这些字段就可以作为复合索引
mysql的left join 和right join和join的区别
mysql> select * from a;
| id | name |
| 1 | aaa |
| 2 | bbb |
| 3 | ccc |
select * from b;
| id | name |
| 1 | aaa |
| 2 | bbb |
| 4 | ccc |
mysql> select * from a join b on a.id=b.id;
| id | name | | id | name |
| 1 | aaa | | 1 | aaa |
| 2 | bbb | | 2 | bbb |
可见,join相当于我们平时用的where,就是把两张表中同时满足a.id=b.id的数据找出来;
mysql> select * from a left join b on a.id=b.id;
| id | name | | id | name |
| 1 | aaa | | 1 | aaa |
| 2 | bbb | | 2 | bbb |
| 3 | ccc| | null | null|
可见,left join是以左表(a)为参考对象,相当于做一个for循环,把a表的数据一条一条的读取出来,然后根据a.id=b.id的条件到b表中查找数据,在b表中找不到数据的,就填充NULL;