If a subquery returns any values at all, then EXISTS
          <subquery> is TRUE, and
          NOT EXISTS <subquery> is
          FALSE. For example:
        
SELECT column1 FROM t1 WHERE EXISTS (SELECT * FROM t2);
          Traditionally an EXISTS subquery starts
          with SELECT * but it could begin with
          SELECT 5 or SELECT
          column1 or anything at all -- MySQL ignores the
          SELECT list in such a subquery, so it
          doesn't matter.
        
          For the above example, if t2 contains any
          rows, even rows with nothing but NULL
          values, then the EXISTS condition is
          TRUE. This is actually an unlikely example,
          since almost always a [NOT] EXISTS subquery
          will contain correlations. Here are some more realistic
          examples.
        
Example: What kind of store is present in one or more cities?
SELECT DISTINCT store_type FROM Stores
  WHERE EXISTS (SELECT * FROM Cities_Stores
                WHERE Cities_Stores.store_type = Stores.store_type);
Example: What kind of store is present in no cities?
SELECT DISTINCT store_type FROM Stores
  WHERE NOT EXISTS (SELECT * FROM Cities_Stores
                    WHERE Cities_Stores.store_type = Stores.store_type);
Example: What kind of store is present in all cities?
SELECT DISTINCT store_type FROM Stores S1
  WHERE NOT EXISTS (
    SELECT * FROM Cities WHERE NOT EXISTS (
      SELECT * FROM Cities_Stores
       WHERE Cities_Stores.city = Cities.city
       AND Cities_Stores.store_type = Stores.store_type));
          The last example is a double-nested NOT
          EXISTS query -- it has a NOT
          EXISTS clause within a NOT EXISTS
          clause. Formally, it answers the question ``does a city exist
          with a store which is not in Stores?''. But it's easier to say
          that a nested NOT EXISTS answers the
          question ``is x TRUE for all y?''.
        
This is a translation of the MySQL Reference Manual that can be found at dev.mysql.com. The original Reference Manual is in English, and this translation is not necessarily as up to date as the English version.

