Как я могу сократить этот MySQL Query? - PullRequest
0 голосов
/ 14 декабря 2009

Здесь,

Есть ли в любом случае сокращение этого запроса MySQL вообще ??? Необходимо получить две разные строки из таблицы PriceRuleDetail из столбца с именем RuleValue на основе правила цены, но при использовании псевдонима они должны быть возвращены в одной строке. Он использует подзапросы внутри оператора select, что, я полагаю, правильно, но может быть более простой способ?

Ниже работает правильно, и я вполне доволен этим, но мне было интересно, есть ли способ сделать это короче ???

SELECT Stock.*, 
    (SELECT PriceRuleDetail.RuleValue
    FROM PriceRuleDetail
    WHERE PriceRuleDetail.Sku = Stock.Sku
    AND PriceRuleDetail.PriceRule = 'RG'
    AND PriceRuleDetail.Quantity = 1) as Price,
    (SELECT PriceRuleDetail.RuleValue
    FROM PriceRuleDetail
    WHERE PriceRuleDetail.Sku = Stock.Sku
    AND PriceRuleDetail.PriceRule = 'RRP'
    AND PriceRuleDetail.Quantity = 1) as WasPrice
FROM Stock, StockCategoryMemberList
WHERE StockCategoryMemberList.Sku = Stock.Sku
AND StockCategoryMemberList.CategoryCode = 'FIRE'

Заранее спасибо.

Andy

Ответы [ 4 ]

6 голосов
/ 14 декабря 2009

Сделайте это одним запросом, с объединениями:

SELECT
   Stock.*, 
   PRD1.RuleValue as Price, 
   PRD2.RuleValue as WasPrice
FROM 
   Stock, 
   StockCategoryMemberList, 
   PriceRuleDetail PRD1, 
   PriceRuleDetail PRD2
WHERE
StockCategoryMemberList.Sku = Stock.Sku
AND StockCategoryMemberList.CategoryCode = 'FIRE'
AND PRD1.Sku = Stock.Sku
    AND PRD1.PriceRule = 'RG'
    AND PRD1.Quantity = 1
AND
    PRD2.Sku = Stock.Sku
    AND PRD2.PriceRule = 'RRP'
    AND PRD2.Quantity = 1

Я сделал то же самое предположение, что и вы (что для одной записи акции есть только одна цена и только одна цена). Если это не так ... запрос не будет в порядке. Ни твоего.

4 голосов
/ 14 декабря 2009

Вы можете использовать левые соединения, чтобы выполнить это

 SELECT Stock.*, 
        PRD1.RuleValue as Price, 
        PRD2.RuleValue as WasPrice
FROM 
   Stock INNER JOIN
   StockCategoryMemberList ON StockCategoryMemberList.Sku = Stock.Sku LEFT JOIN 
   PriceRuleDetail PRD1 ON PRD1.Sku = Stock.Sku
                        AND PRD1.PriceRule = 'RG'
                        AND PRD1.Quantity = 1 LEFT JOIN
   PriceRuleDetail PRD2 ON PRD2.Sku = Stock.Sku
                        AND PRD2.PriceRule = 'RRP'
                        AND PRD2.Quantity = 1
WHERE StockCategoryMemberList.CategoryCode = 'FIRE'
2 голосов
/ 14 декабря 2009
select s.*, prd1.rulevalue as price, prd2.rulevalue as wasprice
from
  stock s
  inner join stockcategorymemberlist scm
      on s.sku = scm.sku
  inner join priceruledetail prd1
      on prd1.sku = s.sku and prd1.pricerule='RG' and prd1.quantity=1
  inner join priceruledetail prd2
      on prd2.sku = s.sku and prd2.pricerule='RRP' and prd2.quantity=1
where
  s.categorycode='FIRE'

Это также будет быстрее, так как вам не придется выполнять каждый из подвыборов для каждой строки в таблице.

0 голосов
/ 14 декабря 2009

Я бы предложил на самом деле увеличить его и не использовать Stock. *, А использовать имя каждого столбца. Когда вы используете *, он должен запросить таблицу, чтобы получить имена столбцов, и это немного медленнее.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...