On 22/07/11 13:20, Chris Curvey wrote:
in an earlier thread, the following query was submitted:

    SELECT COUNT(*) FROM q
          WHERE NOT EXISTS (SELECT 1
                              FROM t AS t
                             WHERE t.mid = q.mid);


and as part of his answer, David Johnson responded


    3. Also, you are using a correlated sub-query instead of a LEFT
    OUTER JOIN


This interests me. How would you rewrite the correlated subquery above using the outer join?

--
e-Mail is the equivalent of a postcard written in pencil. This message may not have been sent by me, or intended for you. It may have been read or even modified while in transit. e-Mail disclaimers have the same force in law as a note passed in study hall. If your corporate attorney says that you need an disclaimer in your signature, you need a new corporate attorney.


DROP TABLE IF EXISTS q;
DROP TABLE IF EXISTS t;


CREATE TABLE q
(
    mid int PRIMARY KEY,
    qnote text
);

CREATE TABLE t
(
    mid int PRIMARY KEY,
    tnote text
);

INSERT INTO q (mid, qnote) VALUES
    (1, 'first'),
    (2, 'second'),
    (4, 'fourth');

INSERT INTO t (mid, tnote) VALUES
    (1, 'first'),
    (3, 'third');

SELECT
    COUNT(*)
FROM
    q LEFT OUTER JOIN t ON (q.mid = t.mid)
WHERE
    t.mid IS NULL;

Reply via email to