mysql的a和b_mysql求助 请问where a.id=b.id 和join on a.id=b.id 在效率上的区别 - join

58e8d81c4a0d115f2a9f9f245fa77d87.png

一.Join语法概述join 用于多表中字段之间的联系,语法如下:... FROM table1 INNER|LEFT|RIGHT JOIN table2 ON conditionatable1:左表;table2:右表。JOIN 按照功能大致分为如下三类:INNER JOIN(内连接,或...

下面是ecshop 的商品表和品牌表的查询,请问它们的查询效率有什么区别呢?

还有一个问题是 left join 和join的效率哪个高一点呢。

谢谢 !!

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS aLEFT JOIN ecs_brand AS b ON a.`brand_id` = b.`brand_id`

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a, ecs_brand AS bWHERE a.`brand_id` = b.`brand_id`

回复讨论(解决方案)

你的第一式是左链接,因无其他过滤条件

结果集中将会有左表(ecs_goods)的全部记录

你的第二式是逗号连接(INNER JOIN 的简写)

结果集中只会出现符合连接条件的记录

两者的作用是不同的,不能做效率比较

当右表(ecs_brand)有过滤条件时

左连接退化为内连接,两式就一样了,没有差别

你的第一式是左链接,因无其他过滤条件

结果集中将会有左表(ecs_goods)的全部记录

你的第二式是逗号连接(INNER JOIN 的简写)

结果集中只会出现符合连接条件的记录

两者的作用是不同的,不能做效率比较

版主 那是不是第一个sql删去left,就和第二个sql完全一样的呢。

它们在效率和索引使用方面有没区别的呢。

当右表(ecs_brand)有过滤条件时

左连接退化为内连接,两式就一样了,没有差别

版主 谢谢你的回答。我还有个问题

比如商品必须选择品牌,就是商品必定存在品牌id。

然后是品牌表肯定有商品的品牌。

所以它们用left join,或是join 返回的结果是一样的。 那这样它们可以进行效率对比吗。

由于连接外有过滤条件,所以 mysql 会将你的查询指令优化成内连接。因此就不存在效率的对比了

当然这里可以对比的是:

在商品表中查品牌商品 和 在品牌表中查商品

两者的效率是不一样的

因为品牌表显然要比商品表小

由于连接外有过滤条件,所以 mysql 会将你的查询指令优化成内连接。因此就不存在效率的对比了

当然这里可以对比的是:

在商品表中查品牌商品 和 在品牌表中查商品

两者的效率是不一样的

因为品牌表显然要比商品表小

版主 谢谢你的回答

我总结了一下你的回答:

第一点:SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a, ecs_brand AS bWHERE a.`brand_id` = b.`brand_id`

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS aJOIN ecs_brand AS b ON a.`brand_id` = b.`brand_id`

两句sql是完全一样的 mysql会将第一条sql优化成第二条。

第二点:

“在商品表中查品牌商品 和 在品牌表中查商品”

就是说

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS aJOIN ecs_brand AS b ON a.`brand_id` = b.`brand_id`

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM ecs_brand AS bJOIN `ecs_goods` AS a ON b.`brand_id`=a.`brand_id`

两句sql的效率是不一样的。

//

以上两点描述正确吗 ?我有没理解错你的意思呢。

如果没有 那第二点大家处理方式都是笛卡尔积。

我的理解是 如果是 ecs_goods` AS a JOIN ecs_brand AS b

那就是商品表的一条记录 扫描品牌表的所有记录。如果有10个商品 10个品牌

那就是10*10=100 扫描了100次

反过来ecs_brand AS b JOIN `ecs_goods` AS a

一个品牌扫描10个商品 那扫描次数也是100次。 那为什么它们的效率不一样呢

呵呵,你自己偷换概念,给自己上个套!完全是为了你的错误观点SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a, ecs_brand AS bWHERE a.`brand_id` = b.`brand_id`和

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a INNER JOIN ecs_brand AS b ON a.`brand_id` = b.`brand_id`

是等效的

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a LEFT JOIN ecs_brand AS b ON a.`brand_id` = b.`brand_id`WHERE b.`field_name`= 123

会被 mysql 优化为

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a, ecs_brand AS bWHERE a.`brand_id` = b.`brand_id`AND b.`field_name`= 123

呵呵,你自己偷换概念,给自己上个套!完全是为了你的错误观点SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a, ecs_brand AS bWHERE a.`brand_id` = b.`brand_id`和

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a INNER JOIN ecs_brand AS b ON a.`brand_id` = b.`brand_id`

是等效的

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a LEFT JOIN ecs_brand AS b ON a.`brand_id` = b.`brand_id`WHERE b.`field_name`= 123

会被 mysql 优化为

SELECT a.`goods_id` , a.`goods_name` , b.brand_nameFROM `ecs_goods` AS a, ecs_brand AS bWHERE a.`brand_id` = b.`brand_id`AND b.`field_name`= 123

版主 这两条语句我试了一下,好像是不相等的阿。

-- -- 表的结构 `good_tbl`-- CREATE TABLE `good_tbl` ( `good_id` int(10) unsigned NOT NULL auto_increment, `brand_id` int(10) unsigned NOT NULL, PRIMARY KEY (`good_id`)) ENGINE=MyISAM DEFAULT CHARSET=gbk AUTO_INCREMENT=4 ;-- -- 导出表中的数据 `good_tbl`-- INSERT INTO `good_tbl` VALUES (1, 2);INSERT INTO `good_tbl` VALUES (2, 3);INSERT INTO `good_tbl` VALUES (3, 2);

-- -- 表的结构 `brand_tbl`-- CREATE TABLE `brand_tbl` ( `brand_id` int(10) unsigned NOT NULL auto_increment, `brand_name` varchar(50) NOT NULL, PRIMARY KEY (`brand_id`)) ENGINE=MyISAM DEFAULT CHARSET=gbk AUTO_INCREMENT=4 ;-- -- 导出表中的数据 `brand_tbl`-- INSERT INTO `brand_tbl` VALUES (1, '诺基亚');INSERT INTO `brand_tbl` VALUES (3, '三星');

版主 请问这些mysql的资料在哪里可以找到的呢,比如怎样知道某些语句在mysql里面会优化成另外的语句呢。

一.Join语法概述join 用于多表中字段之间的联系,语法如下:... FROM table1 INNER|LEFT|RIGHT JOIN table2 ON conditionatable1:左表;table2:右表。JOIN 按照功能大致分为如下三类:INNER JOIN(内连接,或...

一.Join语法概述join 用于多表中字段之间的联系,语法如下:... FROM table1 INNER|LEFT|RIGHT JOIN table2 ON conditionatable1:左表;table2:右表。JOIN 按照功能大致分为如下三类:INNER JOIN(内连接,...

bitsCN.com

详解mysql语法left join,right join,inner join 测试表用户表user:测试表密码表pwd:1、创建user表:1CREATE TABLE `user` (2 `id` int(11) NOT NULL auto_increment,3

本文主要介绍了Mysql join操作的相关资料,需要的朋友可以参考下,希望能帮助到大家。 join的类型1. 内联结:将两个表中存在联结关系的字段符合联结关系的那些记录形成记录集的联结。2. 外联结:分为外...

JOIN方法也是连贯操作方法之一,用于根据两个或多个表中的列之间的关系,从这些表中查询数据。join通常有下面几种类型,不同类型的join操作会影响返回的数据结果。INNER JOIN: 如果...

...。MySQL数据库支持如下的联接查询:

CROSS JOIN(交叉联接)

INNER JOIN(内联接)

OUTER JOIN(外联接)

其它

在进行各种联接操作时,一定要回忆一下在《SQL逻辑查询语句执...

...)中,表连接的语法可以参见MySQL官方手册:MySQL官方手册-JOIN在查询中,连接的语法类似SELECT select_expr FROM table_referencestable_references(对表的引用)的定义如下(也可以看成

inner join(等值连接):只返回两个表中联结字段相等的行。left join(左联接):返回包括左表中的所有记录和右表中联结字段相等的记录。right join(右联接):返回包括右表中的所有记录和左表中联结字段相等的记录。

数据库常见的join方式有三种:inner join, left outter join, right outter join(还有一种full join,因不常用,本文不讨论)。这三种连接方式都是将两个以上的表通过on条件语句,拼成一个大表。

以下是它们的共同点:...

LEFT JOIN 语法用法与实例MySQL LEFT JOIN 语法SQL(MySQL) LEFT JOIN 会取得左表(table1)全部记录,即使右表(table2)并无对应匹配记录。LEFT JOIN 基本语法如下:... FROM table1 LEFT JOIN table2 ON co

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值