sql >> Databasteknik >  >> RDS >> Mysql

INTERSECT i MySQL

Du kan använda en inre koppling för att filtrera efter rader som har en matchande rad i en annan tabell:

SELECT DISTINCT records.id 
FROM records
INNER JOIN data d1 on d1.id = records.firstname AND data.value = "john"
INNER JOIN data d2 on d2.id = records.lastname AND data.value = "smith"

Ett av många andra alternativ är en in klausul:

SELECT DISTINCT records.id 
FROM records
WHERE records.firstname IN (
    select id from data where value = 'john'
) AND records.lastname IN (
    select id from data where value = 'smith'
)


  1. Handledning om SQL (DDL, DML) om exemplet på MS SQL Server-dialekt

  2. Hur man uppdaterar en kolumn baserat på en annan kolumn i SQL

  3. Installera Microsoft SQL Server JDBC-drivrutiner i Pentaho Data Integration och BA Server-verktyg

  4. MySQL's now() +1 dag