sql >> Database >  >> RDS >> Mysql

Unieke rijen selecteren in een set van twee mogelijkheden

Dit komt redelijk overeen met wat u schreef, maar zou redelijk snel moeten zijn, aangezien NOT EXISTS in dit geval efficiënter is dan NOT IN...

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. Hoe de laatste 2 items per categorie in één keer te krijgen (met mysql)

  2. Een paar snelle dingen over PASS-feedback

  3. Unitils en DBMaintainer - hoe kan ik ze laten werken met meerdere gebruikers/schema's?

  4. Wanneer moet ik de mysqli (Database) verbinding sluiten?