sql >> Databasteknik >  >> RDS >> Mysql

Mysql Inner join med OR-villkor?

Du kan gå med på location_distance tabell två gånger med en LEFT JOIN och använd sedan COALESCE() funktion för att returnera det korrekta värdet för distance :

select ot.id,
  ot.fromlocid,
  ot.tolocid,
  ot.otherdata,
  coalesce(ld1.distance, ld2.distance) distance
from other_table ot
left join location_distance ld1
  on ld1.fromLocid = ot.toLocid
  and ld1.toLocid = ot.fromLocid 
left join location_distance ld2
  on ld2.toLocid = ot.toLocid
  and ld2.fromLocid = ot.fromLocid 

Se SQL-fiol med demo

Detta returnerar resultatet:

| ID | FROMLOCID | TOLOCID | OTHERDATA | DISTANCE |
---------------------------------------------------
| 12 |         5 |       3 |      xxxx |       70 |
| 22 |         2 |       4 |      xxxx |       63 |
| 56 |         8 |       6 |      xxxx |       15 |
| 78 |         3 |       5 |      xxxx |       70 |


  1. Verifierar MySQLi servercertifikat som standard när man använder SSL?

  2. Syntaxfel:WITH är inte giltig inmatning i denna position

  3. ADO.NET anropar T-SQL lagrad procedur orsakar ett SqlTimeoutException

  4. De 30 bästa intervjufrågorna för SQL-frågor du måste öva under 2022