草庐IT

most_inner

全部标签

即使使用 INNER JOIN 而不是 IN,MySQL 查询也非常慢

我有三个表:product(10k条记录)、product_attribute(4k条记录)和product_value(2m条记录)。product和product_attribute通过product_value连接。我想检索特定产品(例如,product_id=001)及其各自的属性名称和属性值。一开始,我尝试SELECTproduct.product_id,product_attribute.attribute_name,product_value.attribute_valueFROMproduct,product_attribute,product_valueWHEREpr

mysql - 如何在 mysql 的 select 中使用 inner join?

我想在以下条件下从mysql数据库中获取记录我有以下表格:组织_表organizationId|organizationname事件表camp_id|camp_name|adv_id|organizationId广告表adv_id|adv_namead_display表ad_displayId|adv_id|camp_id|现在我想从ad_display表中获取这样的记录:|adv_name|camp_name|organizationnameWithWHERE条件为WhereorganizationId==?所以基本上我想要广告系列的广告列表,其中organization_id=?N

mysql - 父表中的两个外键引用同一个子表。如何构造INNER JOIN?

为简单起见,我将在此处将我的问题描述为理论问题。假设您有两个表格——MATCHES和FIGHTERS。'Fighters'有一个战士列表(pk_fighter_id,fighter_name),其中任何两个都可以被安排来互相对战。“匹配”可能是一个三字段表(pk_fight_num、fk_fighter_id1、fk_fighter_id2),用于跟踪这些配对。Fighter1和Fighter2是引用Fighters表中条目的外键。我需要获取所有战斗的列表,以显示谁在与谁战斗,即“23123|Pacquaio|Marquez”。不过,我到底该如何构造我的查询?我想是这样的:select

mysql - 为什么 LEFT JOIN 比 INNER JOIN 慢?

我有两个查询,第一个(内连接)超快,第二个(左连接)超慢。如何使第二个查询更快?EXPLAINSELECTsaved.emailFROMsavedINNERJOINfinishedONfinished.email=saved.email;idselect_typetabletypepossible_keyskeykey_lenrefrowsExtra1SIMPLEfinishedindexNULLemail258NULL32168Usingindex1SIMPLEsavedrefemailemail383func1Usingwhere;UsingindexEXPLAINSELECTsa

Mysql Count with Inner join of two tables, Average Join

我很想连接两个表,但似乎无法正确连接,结构如下所示。表1(成员)[用户登录|姓名]表2(文章)[艺术编号|作家|内容]Article.writer指向Members.UserLogin我想用尽可能少的代码显示已注册UserLogins的整个列表,以及他们可能写了多少文章的计数,​​或者如果他们没有写过任何文章,他们也应该在列表中.我想要什么:[用户登录|名称|文章撰写]到目前为止我得到的是:SELECTUserLogin,Name,Writer,count(*)FROMArticleINNERJOINMembersonWriter=UserLoginGROUPBYUserLogin;或

mysql - 如何使用 INNER JOIN 和 ORDER BY 优化 MySQL 查询

给出这个查询:EXPLAINSELECTmi.*,i1.sizesastile_photo_sizes,i1.filenameastile_photo_filename,v.title_cachedasvenue_title,v.subtitle_cachedasvenue_subtitle,v.slugasvenue_slugFROMmenuitemsmiINNERJOINimagesi1ONi1.id=mi.tile_photo_idINNERJOINmenusmONm.id=mi.menu_idINNERJOINvenuesvONv.id=m.venue_idWHERENOTm.

MySQL inner join 3个表

假设我有3张table乘客(身份证[pk],姓名)飞机(登记[pk],num_seats)预订(Id,passenger_id[fk->Passenger.Id],airplane_registration[fk->Airplane.registration])这里的预订表将是一个连接对象,因为表Passenger和Booking之间存在多对多关系。我如何选择与特定预订ID(例如“abcde”)相关的所有详细信息?这是正确的吗:SELECTPassenger.name,Airplane.num_seats,Booking.IdFROMBookingJOINPassengerONPass

SQL 固定值 IN() 与 INNER JOIN 性能

回答thisSQLquestion,遇到过这样的说法,固定值IN()运算符比同样内容的INNERJOIN慢很多,以至于不如创建临时的值的表并加入它们。它是真的吗(一般来说,对于MySQL,任何其他SQL引擎)如果是的话-为什么?直觉上,IN应该更快-您正在将潜在匹配与一组固定值进行比较,这些值已经在内存中并且采用所需的格式,而使用JOIN您必须查询索引,可能从磁盘加载数据,并执行IN可能不需要的其他操作。我错过了什么重要的东西吗?请注意,与thisquestion不同它有很多重复项,我说的是IN()具有固定的值集,而不是子查询。 最佳答案

mysql - 使用昂贵的 INNER JOIN 优化 MySQL 查询

通过反复试验,我发现当从下面的查询中删除连接时,它的运行速度提高了大约30倍。有人可以解释为什么会这样,以及是否可以优化查询以包含额外的连接而不影响性能。这是说明的屏幕截图,显示索引未用于uesr_groups表。http://i.imgur.com/9VDuV.png这是原始查询:SELECT`comments`.`comment_id`,`comments`.`comment_html`,`comments`.`comment_time_added`,`comments`.`comment_has_attachments`,`users`.`user_name`,`users`.`

mysql - 什么时候最好不要使用 inner join?

我有两个表:table1(id,name,connte)table2(id,name,connte)它们通过table1.connte和table2.connte连接。每条记录包含100条记录。现在,如果我想从表1中删除一条id=20的记录及其在表2中的相应子项,是否最好执行以下操作:DELETEd1,d2FROMtable1d1INNERJOINtable2d2ONd1.connte=d2.connteWHEREd1.id=20或以下内容:selectconntefromtable1whereid=20--Storeconnteinavariablesayaabc--deletefr