sql >> Databasteknik >  >> RDS >> Mysql

Välja unika rader i en uppsättning av två möjligheter

Detta är ganska likt det du skrev, men bör vara ganska snabbt eftersom INTE FINNS är mer effektivt, i det här fallet, än INTE I...

mysql> select * from foo;
+----+-----+
| id | col |
+----+-----+
|  1 | Bar | 
|  1 | Foo | 
|  2 | Foo | 
|  3 | Bar | 
|  4 | Bar | 
|  4 | Foo | 
+----+-----+

SELECT id
     , col
  FROM foo f1 
 WHERE col = 'Foo' 
  OR ( col = 'Bar' AND NOT EXISTS( SELECT * 
                                     FROM foo f2
                                    WHERE f1.id  = f2.id 
                                      AND f2.col = 'Foo' 
                                 ) 
     ); 

+----+-----+
| id | col |
+----+-----+
|  1 | Foo | 
|  2 | Foo | 
|  3 | Bar | 
|  4 | Foo | 
+----+-----+


  1. Var lagrar Android SQLites databasversion?

  2. Hur använder man ett variabelnamn i en SQL-sats?

  3. SQL-nycklar, MUL vs PRI vs UNI

  4. Hur man gör en Full Outer Join i MySQL