2

2 つのかなり異なるクエリからの数値結果を分割しようとしています。

最終結果は、Query 1 DIVIDED BY Query 2 になります。

クエリ 1 =

SELECT COUNT(DISTINCT(table1.ID)) AS count_1
FROM table1 
    INNER JOIN op 
    INNER JOIN Org 
    ON table1.EID = op.id 
        AND Op.OrgID = Org.ID
WHERE table1.TitleID = 123
    AND op.BrandID = 1 
    AND op.Start <= NOW() AND op.End >= NOW();

クエリ 2 =

SELECT COUNT(DISTINCT user.id) AS count_2
FROM table1 INNER JOIN user INNER JOIN ur
    ON table1.EID = user.id AND ur.userID = user.id
WHERE 
    user.BrandID = 1 
    AND table1.TitleID = 123
    AND ur.role = 0
    AND user.Inactive = 0;
4

3 に答える 3

5

もちろん!サブセレクトを使用してこれを実現できますが、かなり冗長になります。

SELECT
(
    SELECT COUNT(DISTINCT(table1.ID)) AS count_1
    FROM table1 
        INNER JOIN op 
        INNER JOIN Org 
        ON table1.EID = op.id 
            AND Op.OrgID = Org.ID
    WHERE table1.TitleID = 123
        AND op.BrandID = 1 
        AND op.Start <= NOW() AND op.End >= NOW()
) / (
    SELECT COUNT(DISTINCT user.id) AS count_2
    FROM table1 INNER JOIN user INNER JOIN ur
        ON table1.EID = user.id AND ur.userID = user.id
    WHERE 
        user.BrandID = 1 
        AND table1.TitleID = 123
        AND ur.role = 0
        AND user.Inactive = 0
);

しかし、それはあなたにとって最も醜いものではありません。

于 2013-09-30T20:45:05.487 に答える
3

次のようなサブクエリを使用します。

SELECT Q1.count_1 / Q2.Count_2 
FROM 
( ... Query1 ...) AS Q1
JOIN
( ... Query2 ...) AS Q2
ON 1=1

コードとして Query1 と Query2 を置き換えます。

于 2013-09-30T20:44:15.307 に答える
2

このような:

SELECT count_1 / count_2
FROM (SELECT COUNT(*) count_1 FROM foo) f
JOIN  (SELECT COUNT(*) count_2 FROM bar) b ON 1=1;

http://sqlfiddle.com/#!2/c215e/1

于 2013-09-30T20:44:21.703 に答える