sql优化以及left join和right join的区别

sql优化:

  1. 只返回需要的数据

a) 不要写SELECT *的语句

b) 合理写WHERE子句,不要写没有WHERE的SQL语句。

  1. 尽量少做重复的工作

使用join代替子查询

  1. 适当建立索引(不是越多越好)但以下几点会进行全表扫描

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;

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值