大家好,又见面了,我是你们的朋友全栈君。
1.on 后面的条件和where 后面的条件的区别
查询语句开始 会根据 on后面的条件创建一张虚拟表,左边表是全部数据,右边表会根据on后面的条件进行筛选。
然后再根据where后面的条件进行筛选虚拟表中的数据作为最终数据
所以如果是筛选右表中的条件 放在了where 中则则会过滤掉 部分左表中的数据
结论:筛选右表的条件和左右表关联的条件写在on中 筛选左表的条件写在where中
2.右表中的条件放在on中 如果右表的数据量很大的情况下会有很长的查询时间 是因为创建虚拟表的时候由于数据量大 查询条件没有索引造成的 所以相应的增加索引进行查询。
3.创建索引
alter table tableName add Index indexName(clum);
ALTER TABLE optable_task_item ADD INDEX task_id ( `task_id` );
4.那么where 中的条件创建索引时候有用呢?
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/130996.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...