2

プロジェクション自体にないフィールドで、SQLクエリの結果を並べ替えることはできますか?

以下の例を参照してください-私は製品テーブルの個別のIDを取得していますが、タイトル順に並べてほしいです。NHibernateを使用してクエリを生成し、結果をページングしているため、タイトルを含めたくありません。次に、この個別のID結果セットを使用して、実際の結果をロードします。

SELECT
DISTINCT this_.`ID` AS y0 
FROM
`Product` this_ 
LEFT OUTER JOIN
`Brand` brand3_ 
ON this_.BrandId=brand3_.ID 
INNER JOIN
`Product_CultureInfo` productcul2_ 
ON this_.ID=productcul2_.ProductID 
AND (
(
(
productcul2_.`Deleted` = 0 
OR productcul2_.`Deleted` IS NULL
) 
AND (
productcul2_.`_Temporary_Flag` = 0 
OR productcul2_.`_Temporary_Flag` IS NULL
)
)
) 
INNER JOIN
`ProductCategory` aliasprodu1_ 
ON this_.ID=aliasprodu1_.ProductID 
AND (
(
(
aliasprodu1_.`Deleted` = 0 
OR aliasprodu1_.`Deleted` IS NULL
) 
AND (
aliasprodu1_.`_Temporary_Flag` = 0 
OR aliasprodu1_.`_Temporary_Flag` IS NULL
)
)
) 
WHERE
(
this_._Temporary_Flag =FALSE
OR this_._Temporary_Flag IS NULL
) 
AND this_.Published = TRUE
AND (
this_.Deleted = FALSE
OR this_.Deleted IS NULL
) 
AND (
this_._ComputedDeletedValue = FALSE
OR this_._ComputedDeletedValue IS NULL
) 
AND (
(
this_._TestItemSessionGuid IS NULL 
OR this_._TestItemSessionGuid = ''
)
) 
AND (
productcul2_._ActualTitle LIKE '%silver%' 
OR brand3_.Title LIKE '%silver%' 
OR aliasprodu1_.CategoryId IN (
47906817 , 47906818 , 47906819 , 47906816 , 7012353 , 44662785 
)
) 
AND this_.Published = TRUE
AND this_.Published = TRUE
ORDER BY
this_.Priority ASC,
productcul2_._ActualTitle ASC,
this_.Priority ASC LIMIT 25;
4

1 に答える 1

1

より良い解決策があるかどうかはわかりませんが、外部クエリが関心のないフィールドを除外するネストされた選択はどうですか?

つまり、「ランダム」テーブルでのそのようなもの

SELECT a,b,c from (SELECT a,b,c,d from myTable order by d)

明らかに、「言語直接」ソリューションがある場合は、そのように2つの投影を行う必要があり、そのうちの1つは役に立たないため、より良いでしょう。

于 2012-05-28T15:21:52.760 に答える