Ако разбирам въпроса ви правилно, за да отговорите на частта за връщане само в една посока, моля, опитайте заявката по-долу:
SELECT d1.*
FROM train_schedule d1
INNER JOIN train_schedule d2 ON d2.train_no=d1.train_no
WHERE d1.stn_code = 'JU' and d2.stn_code = 'JP'
AND d1.distance < d2.distance
JU (заминаване) винаги ще има разстояние, по-малко от JP (пристигане).