jjzjj

sql - 如何在 MYSQL 中优化此查询?需要做什么

coder 2023-10-26 原文

请向下滚动到“25/08/2010 更新”。

我有一个已转换为 View 的查询。它运行非常缓慢,因为(据我所知)连接表上的索引存在几个问题。


explain select * from view_ed_abc_print


如您所见,我有一个使用 where、temporary 和 filesort 的表“a”,其中包含 4659 行,据我所知,这意味着它必须为返回的每一行运行 4659 行。

我省略了查询,因为它真的很长,而且这里的格式很糟糕(它来自一个 View ,所以导致了一些问题

有人有什么想法吗?


感谢您到目前为止的回答。我已经为所有外键创建了索引,并向 publicationtypes 和 audittypes 表添加了一个主键(哎呀,那太傻了)

无论如何,这是新的解释

这是查询的 where/from 部分(很抱歉由于某种原因格式丢失了)

 from
   (
      (
         (
            (
               (
                  `auau7859_aba`.`ed_abc_publication_audits` `a` use index(pubid)
                  left join `auau7859_aba`.`public_publications` `p` on
                  (
                     (`p`.`pubid` = `a`.`audit_pubid`)
                  )
               )
               left join `auau7859_aba`.`ed_aba_frequencies` on
               (
                  (
                     `auau7859_aba`.`ed_aba_frequencies`.`frequencyid` = `p`.`pub_frequencyid`
                  )
               )
            )
            left join `auau7859_aba`.`ed_abc_publicationtypes` on
            (
               (
                  `auau7859_aba`.`ed_abc_publicationtypes`.`publicationtypeid` = `p`.`pub_type`
               )
            )
         )
         left join `auau7859_aba`.`ed_abc_audittypes` on
         (
            (`a`.`audit_type` = `auau7859_aba`.`ed_abc_audittypes`.`audittypeid`)
         )
      )
      left join `auau7859_aba`.`Members` `m` on((`m`.`MemID` = `p`.`pub_memid`))
   )   where ((`a`.`audit_active` = 1) and (`p`.`pub_unfinancial` = 0))
   order by `a`.`audit_anps` desc

查询时间现在好多了,但是我想知道是否有可能让表“a”开始使用该键,而不是我读过的“使用文件排序”真的很慢。


根据要求,这里是相关表格的定义。 ed_abc_publication_audits

     CREATE TABLE `ed_abc_publication_audits` (
            `auditid` INT(11) NOT NULL AUTO_INCREMENT,
            `audit_period` INT(11) NULL DEFAULT '0',
            `audit_year` INT(11) NULL DEFAULT '0',
            `audit_pubid` INT(11) NULL DEFAULT '0',
            `audit_frequencyid` INT(11) NULL DEFAULT '0',
            `audit_issues` VARCHAR(50) NULL DEFAULT NULL,
            `audit_exclusions` TINYINT(4) NULL DEFAULT '0',
            `deprecated_dayspublished` INT(11) NULL DEFAULT '0',
            `audit_specialpublishingday` VARCHAR(50) NULL DEFAULT NULL,
            `audit_bumperissues` TINYINT(4) NULL DEFAULT '0',
            `audit_bumperissuedates` TEXT NULL,
            `audit_bumperissuelinked` TINYINT(4) NULL DEFAULT '0',
            `audit_excludeddates` TEXT NULL,
            `audit_coverprice` DECIMAL(10,2) NULL DEFAULT '0.00',
            `audit_coverpriceday` VARCHAR(100) NULL DEFAULT '0',
            `audit_coverprice2` DECIMAL(10,2) NULL DEFAULT '0.00',
            `audit_coverprice2day` VARCHAR(100) NULL DEFAULT '0',
            `audit_coverprice3` DECIMAL(10,2) NULL DEFAULT '0.00',
            `audit_coverprice3day` VARCHAR(100) NULL DEFAULT '0',
            `audit_osmoney` INT(11) NULL DEFAULT '0',
            `audit_type` INT(11) NULL DEFAULT '0',
            `audit_anps` INT(11) NULL DEFAULT '0',
            `audit_inexcess` TINYINT(4) NULL DEFAULT '0',
            `audit_periodadjustment` TINYINT(4) NULL DEFAULT '0',
            `audit_periodadjustmentvalue` INT(11) NULL DEFAULT '0',
            `audit_nznps` INT(11) NULL DEFAULT '0',
            `audit_nzinexcess` TINYINT(4) NULL DEFAULT '0',
            `audit_othercountries` INT(11) NULL DEFAULT '0',
            `audit_ocinexcess` TINYINT(4) NULL DEFAULT '0',
            `audit_inclaccomairlinesales` DOUBLE NULL DEFAULT '0',
            `audit_incleducationalsales` DOUBLE NULL DEFAULT '0',
            `audit_incleventsales` DOUBLE NULL DEFAULT '0',
            `audit_inclmultiplepublicationsales` DOUBLE NULL DEFAULT '0',
            `audit_bundledsales` DOUBLE NULL DEFAULT NULL,
            `audit_exclaustraliaother` INT(11) NULL DEFAULT '0',
            `audit_exclinexcess` TINYINT(4) NULL DEFAULT '0',
            `audit_nimcopiesprinted` INT(11) NULL DEFAULT '0',
            `audit_nimcopiesdelivered` INT(11) NULL DEFAULT '0',
            `audit_nimcopiesmailed` INT(11) NULL DEFAULT '0',
            `audit_remarks` TEXT NULL,
            `audit_coverprice4day` INT(10) NULL DEFAULT NULL,
            `audit_coverprice4` DECIMAL(10,2) NULL DEFAULT NULL COMMENT 'CoverPrice4',
            `audit_issuesaudited` INT(10) NULL DEFAULT NULL,
            `audit_nonpublishingdates` VARCHAR(45) NULL DEFAULT NULL,
            `audit_digital_anps` INT(10) NULL DEFAULT NULL,
            `audit_digital_inclaccomairlinesales` DOUBLE NULL DEFAULT NULL,
            `audit_digital_incleducationalsales` DOUBLE NULL DEFAULT NULL,
            `audit_digital_incleventsales` DOUBLE NULL DEFAULT NULL,
            `audit_digital_inclmultiplepublicationsales` DOUBLE NULL DEFAULT NULL,
            `audit_digital_bundledsalesdigital` DOUBLE NOT NULL,
            `deprecated_FirstSignatoryName` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_FirstSignatoryEmail` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_SecondSignatoryName` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_SecondSignatoryEmail` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_FormStatus` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_dateSubmitted` VARCHAR(255) NULL DEFAULT NULL,
            `audit_datecreated` TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00',
            `deprecated_dateSignatoryApproved` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_AuditorName` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_AuditorEmail` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_dateAuditorApproved` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_nPeriod` INT(11) NULL DEFAULT NULL,
            `deprecated_nYear` INT(10) NULL DEFAULT NULL,
            `audit_totalissuesaudited` INT(10) NULL DEFAULT NULL,
            `audit_parentpublication` INT(10) NULL DEFAULT NULL,
            `audit_auditenddate` VARCHAR(20) NULL DEFAULT NULL,
            `audit_digital_bumperissuedates` TEXT NULL,
            `audit_digital_bumperissues` TINYINT(4) NULL DEFAULT NULL,
            `audit_digital_bumperissueslinked` TINYINT(4) NULL DEFAULT NULL,
            `audit_digital_coverprice2` DECIMAL(10,2) NULL DEFAULT NULL,
            `audit_digital_coverprice2day` VARCHAR(25) NULL DEFAULT NULL,
            `audit_digital_coverprice3` DECIMAL(10,2) NULL DEFAULT NULL,
            `audit_digital_coverprice3day` VARCHAR(25) NULL DEFAULT NULL,
            `audit_digital_coverprice4` DECIMAL(10,2) NULL DEFAULT NULL,
            `audit_digital_coverprice4day` VARCHAR(25) NULL DEFAULT NULL,
            `audit_digital_coverprice` DECIMAL(18,2) NULL DEFAULT NULL,
            `audit_digital_coverpriceday` VARCHAR(25) NULL DEFAULT NULL,
            `audit_daysbetween` INT(11) NULL DEFAULT NULL,
            `audit_digital_excludeddates` TEXT NULL,
            `audit_digital_issuesaudited` INT(11) NULL DEFAULT NULL,
            `audit_digital_issues` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_lodgementstatus` VARCHAR(255) NULL DEFAULT NULL,
            `deprecated_lodgementtype` VARCHAR(255) NULL DEFAULT NULL,
            `audit_nimaveragecopiesdelivered` INT(11) NULL DEFAULT NULL,
            `audit_nimaveragecopiesmailed` INT(11) NULL DEFAULT NULL,
            `audit_nimaveragecopiesprinted` INT(11) NULL DEFAULT NULL,
            `audit_digital_nonpublishingdates` VARCHAR(45) NULL DEFAULT NULL,
            `Remarks` TEXT NULL,
            `audit_digital_remarks` TEXT NULL,
            `deprecated_s2complete` INT(11) NULL DEFAULT NULL,
            `deprecated_s3complete` INT(11) NULL DEFAULT NULL,
            `audit_stageid` INT(11) NULL DEFAULT NULL,
            `audit_periodenddate` DATE NULL DEFAULT NULL,
            `audit_periodstartdate` DATE NULL DEFAULT NULL,
            `audit_dayspublished` SET('mon','tue','wed','thu','fri','sat','sun') NULL DEFAULT NULL,
            `audit_active` TINYINT(1) UNSIGNED NULL DEFAULT '1',
            `deprecated_auditor_name` VARCHAR(255) NULL DEFAULT NULL COMMENT 'abc_status',
            `audit_auditor_id` INT(10) NULL DEFAULT NULL COMMENT 'This is the auditor ID that has been pulled from the abc status table. WARNING: THIS IS from abcUSERS',
            `deprecated_auditor_email` VARCHAR(255) NULL DEFAULT NULL COMMENT 'abc_status',
            `deprecated_publisher_name` VARCHAR(255) NULL DEFAULT NULL COMMENT 'abc_status',
            `audit_author_id` INT(10) NULL DEFAULT NULL COMMENT 'the author id from the abc_status. WARNING: ABCUsers TAble, not scmod',
            `deprecated_publisher_email` VARCHAR(255) NULL DEFAULT NULL COMMENT 'abc_status',
            PRIMARY KEY (`auditid`),
            INDEX `pubid` (`audit_pubid`),
            INDEX `audit_type` (`audit_type`),
            INDEX `audit_periodenddate` (`audit_periodenddate`),
            INDEX `audit_periodstartdate` (`audit_periodstartdate`),
            INDEX `audit_anps` (`audit_anps`),
            INDEX `orderby` (`audit_pubid`, `audit_anps`)
        )
        COMMENT='aba_cmt'
        COLLATE='latin1_swedish_ci'
        ENGINE=MyISAM
        ROW_FORMAT=DEFAULT
        AUTO_INCREMENT=5483

public_publications 表 (p)

CREATE TABLE `public_publications` (
    `pubid` INT(11) NOT NULL AUTO_INCREMENT,
    `pub_memid` DOUBLE NULL DEFAULT NULL,
    `pub_ledger_code` VARCHAR(255) NULL DEFAULT NULL,
    `pub_title` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_previousname` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_tSummaryTitle` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_bBillPublisher` DOUBLE NULL DEFAULT NULL,
    `deprecated_bBillOtherMember` DOUBLE NULL DEFAULT NULL,
    `deprecated_BillMemID` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_BBillAdHocAddress` DOUBLE NULL DEFAULT NULL,
    `pub_address` VARCHAR(255) NULL DEFAULT NULL,
    `pub_suburb` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_state1` VARCHAR(255) NULL DEFAULT NULL,
    `pub_mlocation` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_postcode` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_membership_amount` DOUBLE NULL DEFAULT NULL,
    `deprecated_receipt_date` VARCHAR(255) NULL DEFAULT NULL,
    `pub_abc` DOUBLE NULL DEFAULT NULL,
    `pub_unfinancial` TINYINT(1) NULL DEFAULT '0',
    `pub_auditmemid` DOUBLE NULL DEFAULT NULL,
    `deprecated_auditorid` DOUBLE NULL DEFAULT NULL,
    `pub_audittype` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_PubType` DOUBLE NULL DEFAULT NULL,
    `pub_classification` INT(11) NULL DEFAULT NULL,
    `deprecated_OldPubID` DOUBLE NULL DEFAULT NULL,
    `deprecated_OldCompanyID` DOUBLE NULL DEFAULT NULL,
    `pub_contactid` DOUBLE NULL DEFAULT NULL,
    `pub_auditremarks` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_bGovernment` DOUBLE NULL DEFAULT NULL,
    `deprecated_bExGovernment` DOUBLE NULL DEFAULT NULL,
    `deprecated_dDateJoined` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_tDaysPublished` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_stateid` VARCHAR(50) NULL DEFAULT NULL,
    `deprecated_PublisherCost` DOUBLE NULL DEFAULT NULL,
    `pub_magazinecategory` DOUBLE NULL DEFAULT NULL,
    `deprecated_dayspublished` DOUBLE NULL DEFAULT NULL,
    `pub_frequency` VARCHAR(255) NULL DEFAULT NULL,
    `pub_type` INT(11) NULL DEFAULT NULL,
    `pub_subtype` VARCHAR(255) NULL DEFAULT NULL,
    `deprecated_MYOBExport` DOUBLE NULL DEFAULT NULL,
    `deprecated_periodJAN-JUNE` DOUBLE NULL DEFAULT NULL,
    `deprecated_periodJUL-DEC` DOUBLE NULL DEFAULT NULL,
    `deprecated_periodJAN-MAR` DOUBLE NULL DEFAULT NULL,
    `deprecated_periodAPR-JUN` DOUBLE NULL DEFAULT NULL,
    `deprecated_periodJUL-SEPT` DOUBLE NULL DEFAULT NULL,
    `deprecated_periodOCT-DEC` DOUBLE NULL DEFAULT NULL,
    `deprecated_periodApr-Mar` DOUBLE NULL DEFAULT NULL,
    `deprecated_periodOct-Sept` DOUBLE NULL DEFAULT NULL,
    `deprecated_UnfinancialDate` VARCHAR(255) NULL DEFAULT NULL,
    `pub_location` VARCHAR(255) NULL DEFAULT NULL,
    `Address` VARCHAR(255) NULL DEFAULT NULL COMMENT 'Address',
    `deprecated_AuditorName` VARCHAR(255) NULL DEFAULT NULL COMMENT 'use pub_auditorid instead. ',
    `deprecated_AuditorEmail` VARCHAR(255) NULL DEFAULT NULL COMMENT 'use pub_auditorid instead. ',
    `pub_auditflag` VARCHAR(45) NULL DEFAULT NULL,
    `pub_datemodified` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
    `pub_website` VARCHAR(255) NULL DEFAULT NULL,
    `pub_mastheadurl` VARCHAR(255) NULL DEFAULT NULL,
    `pub_frequencyid` INT(11) NULL DEFAULT NULL,
    `pub_nimparentpubid` INT(11) NULL DEFAULT NULL,
    `pub_active` TINYINT(4) NULL DEFAULT NULL,
    `remove_datemodified` TIMESTAMP NULL DEFAULT NULL,
    `pub_datecreated` TIMESTAMP NULL DEFAULT NULL,
    `pub_dayspublished` SET('mon','tue','wed','thu','fri','sat','sun') NULL DEFAULT NULL,
    `pub_state` VARCHAR(10) NULL DEFAULT NULL,
    `pub_contact_vote` INT(10) NULL DEFAULT NULL,
    `pub_contact_auditletter1` INT(10) NULL DEFAULT NULL,
    `pub_contact_auditletter2` INT(10) NULL DEFAULT NULL,
    `pub_auditorid` INT(10) NULL DEFAULT NULL COMMENT 'Put the user id of the auditor in this field for ABC elodgement. (see sc_module_users user_id, listed in the module > users page in edata backend)',
    `pub_next_audit_period` INT(10) NULL DEFAULT NULL,
    `pub_next_audit_type` INT(10) NULL DEFAULT NULL,
    PRIMARY KEY (`pubid`),
    INDEX `Index_2` (`pub_title`),
    INDEX `Unfinancial` (`pub_unfinancial`),
    INDEX `lPublicationType` (`pub_type`)
)
COLLATE='latin1_swedish_ci'
ENGINE=MyISAM
ROW_FORMAT=DEFAULT
AUTO_INCREMENT=20000

成员(m)

CREATE TABLE `Members` (
    `MemID` INT(11) NOT NULL AUTO_INCREMENT,
    `ABC` INT(11) NOT NULL,
    `Mem_Type_ID` SMALLINT(6) NOT NULL,
    `Membership Status` VARCHAR(80) NULL DEFAULT NULL,
    `reference` VARCHAR(255) NULL DEFAULT NULL,
    `CABReference` VARCHAR(50) NULL DEFAULT NULL,
    `Company_Name` VARCHAR(255) NOT NULL,
    `Street_Address` VARCHAR(255) NULL DEFAULT NULL,
    `Street_Address_Line2` VARCHAR(100) NULL DEFAULT NULL,
    `Suburb` VARCHAR(255) NULL DEFAULT NULL,
    `State` VARCHAR(255) NULL DEFAULT NULL,
    `Post_Code` VARCHAR(255) NULL DEFAULT NULL,
    `unfinancial` TINYINT(1) NULL DEFAULT NULL,
    `file` VARCHAR(255) NULL DEFAULT NULL,
    `Phone` VARCHAR(255) NULL DEFAULT NULL,
    `Fax` VARCHAR(255) NULL DEFAULT NULL,
    `WebsiteAddress` VARCHAR(70) NULL DEFAULT NULL,
    `TempAddress` VARCHAR(255) NULL DEFAULT NULL,
    `ABCWebsitePassword` VARCHAR(10) NULL DEFAULT NULL,
    `ABCWebsiteUsername` VARCHAR(10) NULL DEFAULT NULL,
    `CABWebsiteUsername` VARCHAR(10) NULL DEFAULT NULL,
    `CABWebsitePassword` VARCHAR(10) NULL DEFAULT NULL,
    `MembershipAmount` DOUBLE NULL DEFAULT NULL,
    `MYOBExport` TINYINT(1) NULL DEFAULT NULL,
    `MYOBTaxCode` VARCHAR(3) NULL DEFAULT NULL,
    `Date_Last_Payment` VARCHAR(40) NULL DEFAULT NULL,
    `Date_Admitted` VARCHAR(40) NULL DEFAULT NULL,
    `Date_Resigned` VARCHAR(40) NULL DEFAULT NULL,
    `masthead_url` VARCHAR(255) NULL DEFAULT NULL,
    `masthead_report` TINYINT(1) NULL DEFAULT '0',
    `masthead_image` VARCHAR(255) NULL DEFAULT NULL,
    `masthead_description` TEXT NULL,
    `masthead_title` VARCHAR(255) NULL DEFAULT NULL,
    PRIMARY KEY (`MemID`),
    INDEX `MemID` (`MemID`)
)
COLLATE='latin1_swedish_ci'
ENGINE=MyISAM
ROW_FORMAT=DEFAULT
AUTO_INCREMENT=12349

至于其他表,它们是相当无关紧要的,尽管如果您认为它们相关,很乐意发布它们,请对其发表评论。

谢谢。这是最新的解释查询结果:

快速总结

  1. 为所有外键添加了索引,并为 publicationtypes 和 audittypes 表添加了主键(这些只是查找表)
  2. 为 public_publications 和 publications_audit 表添加了排序索引

这些大大减少了查询时间,但仍然运行了大约 0.4 秒,总共只有 4300 行左右。

如果您有任何建议,我们将不胜感激!


25/08/2010 更新

经过更多的调试,我意识到如果我从我的 select 子句中删除所有的废话,查询运行得非常快。现在我想知道我的 select 子句中是否有什么东西让它运行得这么慢。

谁能指出这个选择查询有些慢:

 `p`.`pub_memid` AS `pub_memid`,
   `a`.`audit_inexcess` AS `audit_inexcess`,
   `a`.`auditid` AS `auditid`,
   `a`.`audit_period` AS `audit_period`,
   year(`a`.`audit_periodenddate`) AS `audit_year`,
   `p`.`pub_unfinancial` AS `pub_unfinancial`,
   `p`.`pub_title` AS `pub_title`,
   concat(`p`.`pub_title`,_latin1'{%}',`p`.`pubid`) AS `pub_title@display`,
   `p`.`pubid` AS `pubid`,
   `a`.`audit_periodstartdate` AS `audit_periodstartdate`,
   date_format(`a`.`audit_periodstartdate`,_latin1'%b %y') AS `audit_periodstartdate@display`,
   `a`.`audit_periodenddate` AS `audit_periodenddate`,
   date_format(`a`.`audit_periodenddate`,_latin1'%b %y') AS `audit_periodenddate@display`,
   `a`.`audit_type` AS `audit_type`,
   `auau7859_aba`.`ed_abc_audittypes`.`audittype_title` AS `audittype_title`,
   `p`.`pub_state` AS `pub_state`,
   `p`.`pub_location` AS `pub_location`,
   `p`.`pub_dayspublished` AS `pub_dayspublished`,
   `auau7859_aba`.`ed_aba_frequencies`.`frequency_title` AS `frequency_title`,
   `a`.`audit_issues` AS `audit_issues`,
   `a`.`audit_issuesaudited` AS `audit_issuesaudited`,
   if(((`a`.`audit_exclusions` <> 0) or (`a`.`audit_bumperissues` <> 0)),concat(_utf8'*',`a`.`audit_issuesaudited`),`a`.`audit_issuesaudited`) AS `audit_issuesaudited@display`,
   `a`.`audit_coverprice` AS `audit_coverprice`,
   concat(_utf8'$',`a`.`audit_coverprice`) AS `audit_coverprice@display`,
   `a`.`audit_coverpriceday` AS `audit_coverpriceday`,
   date_format(`a`.`audit_periodenddate`,_latin1'%b %y') AS `period_ending`,
   `a`.`audit_remarks` AS `audit_remarks`,
   `p`.`pub_type` AS `pub_type`,
   `auau7859_aba`.`ed_abc_publicationtypes`.`publicationtype_title` AS `publicationtype_title`,
   `a`.`audit_anps` AS `audit_anps`,
   if(`a`.`audit_inexcess`,concat(_utf8'+',format(`a`.`audit_anps`,0)),format(`a`.`audit_anps`,0)) AS `audit_anps@display`,
   if((`a`.`audit_inclaccomairlinesales` > 0),concat(format((`a`.`audit_inclaccomairlinesales` * 100),2),_utf8'%'),_utf8'') AS `audit_inclaccomairlinesales@display`,
   if((`a`.`audit_incleducationalsales` > 0),concat(format((`a`.`audit_incleducationalsales` * 100),2),_utf8'%'),_utf8'') AS `audit_incleducationalsales@display`,
   if((`a`.`audit_incleventsales` > 0),concat(format((`a`.`audit_incleventsales` * 100),2),_utf8'%'),_utf8'') AS `audit_incleventsales@display`,
   if((`a`.`audit_inclmultiplepublicationsales` > 0),concat(format((`a`.`audit_inclmultiplepublicationsales` * 100),2),_utf8'%'),_utf8'') AS `audit_inclmultiplepublicationsales@display`,
   if((`a`.`audit_bundledsales` > 0),concat(format((`a`.`audit_bundledsales` * 100),2),_utf8'%'),_utf8'') AS `audit_bundledsales@display`,
   if((`a`.`audit_nznps` > 0),format(`a`.`audit_nznps`,0),_utf8'') AS `audit_nznps@display`,
   if((`a`.`audit_othercountries` > 0),format(`a`.`audit_othercountries`,0),_utf8'') AS `audit_othercountries@display`,
   if((`a`.`audit_exclaustraliaother` > 0),format(`a`.`audit_exclaustraliaother`,0),_utf8'') AS `audit_exclaustraliaother@display`,
   `a`.`audit_inclaccomairlinesales` AS `audit_inclaccomairlinesales`,
   `a`.`audit_incleducationalsales` AS `audit_incleducationalsales`,
   `a`.`audit_incleventsales` AS `audit_incleventsales`,
   `a`.`audit_inclmultiplepublicationsales` AS `audit_inclmultiplepublicationsales`,
   `a`.`audit_bundledsales` AS `audit_bundledsales`,
   `a`.`audit_nznps` AS `audit_nznps`,
   `a`.`audit_othercountries` AS `audit_othercountries`,
   `a`.`audit_exclaustraliaother` AS `audit_exclaustraliaother`,
   `p`.`pub_mastheadurl` AS `pub_mastheadurl`,
   `a`.`auditid` AS `audit_mastheadlink`,
   concat(ifnull(`a`.`audit_bumperissuedates`,_latin1''),_latin1'{%}',ifnull(`a`.`audit_excludeddates`,_latin1''),_latin1'{%}',ifnull(`a`.`audit_remarks`,_latin1'')) AS `audit_remarks@display`,
   if((ifnull(`a`.`audit_specialpublishingday`,_latin1'') <> _latin1''),concat(ifnull(`p`.`pub_dayspublished`,_latin1''),_latin1'{%}',ifnull(`a`.`audit_specialpublishingday`,_latin1'')),`p`.`pub_dayspublished`) AS `pub_dayspublished@display`,
   `a`.`audit_parentpublication` AS `audit_parentpublication`,
   if((ifnull(`p`.`pub_nimparentpubid`,0) > 0),(select `nimpub`.`pub_title` AS `pub_title` from `auau7859_aba`.`public_publications` `nimpub` where (`nimpub`.`pubid` = `p`.`pub_nimparentpubid`)),_latin1'') AS `audit_parentpublication@display`,
   `a`.`audit_digital_anps` AS `audit_digital_anps`,
   if((`a`.`audit_digital_anps` > 0),format(`a`.`audit_digital_anps`,0),_utf8'') AS `audit_digital_anps@display`,
   `a`.`audit_digital_bumperissuedates` AS `audit_digital_bumperissuedates`,
   `a`.`audit_digital_bumperissues` AS `audit_digital_bumperissues`,
   `a`.`audit_digital_bumperissueslinked` AS `audit_digital_bumperissueslinked`,
   `a`.`audit_digital_coverprice` AS `audit_digital_coverprice`,
   concat(_utf8'$',`a`.`audit_digital_coverprice`) AS `audit_digital_coverprice@display`,
   `a`.`audit_digital_coverprice2` AS `audit_digital_coverprice2`,
   `a`.`audit_digital_coverprice2day` AS `audit_digital_coverprice2day`,
   `a`.`audit_digital_coverprice3` AS `audit_digital_coverprice3`,
   `a`.`audit_digital_coverprice3day` AS `audit_digital_coverprice3day`,
   `a`.`audit_digital_coverprice4` AS `audit_digital_coverprice4`,
   `a`.`audit_digital_coverprice4day` AS `audit_digital_coverprice4day`,
   `a`.`audit_digital_coverpriceday` AS `audit_digital_coverpriceday`,
   `a`.`audit_digital_excludeddates` AS `audit_digital_excludeddates`,
   `a`.`audit_digital_inclaccomairlinesales` AS `audit_digital_inclaccomairlinesales`,
   if((`a`.`audit_digital_inclaccomairlinesales` > 0),concat(format(`a`.`audit_digital_inclaccomairlinesales`,2),_utf8'%'),_utf8'') AS `audit_digital_inclaccomairlinesales@display`,
   `a`.`audit_digital_incleducationalsales` AS `audit_digital_incleducationalsales`,
   if((`a`.`audit_digital_incleducationalsales` > 0),concat(format(`a`.`audit_digital_incleducationalsales`,2),_utf8'%'),_utf8'') AS `audit_digital_incleducationalsales@display`,
   `a`.`audit_digital_incleventsales` AS `audit_digital_incleventsales`,
   if((`a`.`audit_digital_incleventsales` > 0),concat(format(`a`.`audit_digital_incleventsales`,2),_utf8'%'),_utf8'') AS `audit_digital_incleventsales@display`,
   `a`.`audit_digital_inclmultiplepublicationsales` AS `audit_digital_inclmultiplepublicationsales`,
   if((`a`.`audit_digital_inclmultiplepublicationsales` > 0),concat(format(`a`.`audit_digital_inclmultiplepublicationsales`,0),_utf8'%'),_utf8'') AS `audit_digital_inclmultiplepublicationsales@display`,
   `a`.`audit_digital_bundledsalesdigital` AS `audit_digital_bundledsalesdigital`,
   if((`a`.`audit_digital_bundledsalesdigital` > 0),concat(format(`a`.`audit_digital_bundledsalesdigital`,2),_utf8'%'),_utf8'') AS `audit_digital_bundledsalesdigital@display`,
   `a`.`audit_digital_issues` AS `audit_digital_issues`,
   `a`.`audit_digital_issuesaudited` AS `audit_digital_issuesaudited`,
   if(((ifnull(`a`.`audit_digital_excludeddates`,_latin1'') <> _latin1'') or (`a`.`audit_digital_bumperissues` <> 0)),concat(_utf8'*',`a`.`audit_digital_issuesaudited`),`a`.`audit_digital_issuesaudited`) AS `audit_digital_issuesaudited@display`,
   `a`.`audit_digital_nonpublishingdates` AS `audit_digital_nonpublishingdates`,
   `a`.`audit_digital_remarks` AS `audit_digital_remarks`,
   concat(ifnull(`a`.`audit_digital_bumperissuedates`,_latin1''),_latin1'{%}',ifnull(`a`.`audit_digital_excludeddates`,_latin1''),_latin1'{%}',ifnull(`a`.`audit_digital_remarks`,_latin1'')) AS `audit_digital_remarks@display`,
   `m`.`Company_Name` AS `publisher`,
   `auau7859_aba`.`ed_abc_publicationtypes`.`publicationtype_abbreviation` AS `publicationtype_abbreviation`

最佳答案

更详细的问题...

根据我在查询中阅读的内容,您正在执行所有左联接...因此指示左侧表中的所有记录,而不管右侧表中是否存在基于其联接的匹配项。在这种情况下,最内层来自...

ed_abc_publication_audits left-joined to public_publications

但是您的 where 子句通过

在两边限定了一个值
(a.audit_active = 1) and (p.pub_unfinancial = 0)

对我来说,这意味着一个 INNER JOIN,其中记录必须存在于每一侧...

然后您对 auau7859_aba.ed_aba_frequencies、ed_abc_publicationtypes、ed_abc_audittypes 和 Members 执行 LEFT JOINs....

您是否期望在这些更深层次的连接中出现一些不匹配并因此期望 NULL 值,或者您想要的是它们最终在所有级别连接在一起的地方。

但是,看起来其他表的左连接更像是一个查找/引用表,记录应该始终存在。例如

每次发布​​审核都将始终具有有效的“审核类型”

每个出版物都将始终具有“频率 ID”、“出版物类型”和“成员”

我的解释正确吗???查找表总是会有匹配的记录吗?如果是,哪些...如果可选哪些...

根据您的回答,尝试以下查询...如果您了解您的数据、关系并且可以自行优化,STRAIGHT_JOIN 会非常强大,这是驱动系统其余部分的关键表...

SELECT STRAIGHT_JOIN
        a.*,
        p.*
    FROM 
        auau7859_aba.ed_abc_publication_audits a
            left join auau7859_aba.ed_abc_audittypes atypes
                ON a.audit_type = atypes.audittypeid,
        auau7859_aba.public_publications p 
            left join auau7859_aba.ed_aba_frequencies f
                ON p.pub_frequencyid = f.frequencyid
            left join auau7859_aba.ed_abc_publicationtypes t
                ON p.pub_type = t.publicationtypeid
            left join auau7859_aba.Members m 
                on p.pub_memid = m.MemID
    where 
            a.audit_pubid = p.pubid
        and a.Audit_Active = 1
        and p.pub_unfinancial = 0

关于sql - 如何在 MYSQL 中优化此查询?需要做什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3517885/

有关sql - 如何在 MYSQL 中优化此查询?需要做什么的更多相关文章

  1. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  2. ruby - 如何在 Ruby 中顺序创建 PI - 2

    出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits

  3. ruby - 我需要将 Bundler 本身添加到 Gemfile 中吗? - 2

    当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/

  4. ruby-on-rails - Rails - 子类化模型的设计模式是什么? - 2

    我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

  5. ruby - ECONNRESET (Whois::ConnectionError) - 尝试在 Ruby 中查询 Whois 时出错 - 2

    我正在用Ruby编写一个简单的程序来检查域列表是否被占用。基本上它循环遍历列表,并使用以下函数进行检查。require'rubygems'require'whois'defcheck_domain(domain)c=Whois::Client.newc.query("google.com").available?end程序不断出错(即使我在google.com中进行硬编码),并打印以下消息。鉴于该程序非常简单,我已经没有什么想法了-有什么建议吗?/Library/Ruby/Gems/1.8/gems/whois-2.0.2/lib/whois/server/adapters/base.

  6. ruby - 如何在 buildr 项目中使用 Ruby 代码? - 2

    如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby​​

  7. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  8. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  9. ruby - 为什么 4.1%2 使用 Ruby 返回 0.0999999999999996?但是 4.2%2==0.2 - 2

    为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返

  10. ruby-on-rails - 如何在 ruby​​ 中使用两个参数异步运行 exe? - 2

    exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby​​中使用两个参数异步运行exe吗?我已经尝试过ruby​​命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何ruby​​gems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除

随机推荐