Twoje zapytanie jest uproszczone prawie do punktu bełkotu, ale coś takiego powinno działać.
SELECT ...
FROM ....
INNER JOIN (SELECT '2017-12-01' AS beginDate, '2017-12-30' AS endDate) AS dr
ON (ship.dateShipped BETWEEN dr.beginDate AND dr.endDate)
OR (fulfill.datefulfilled BETWEEN dr.beginDate AND dr.endDate)
...
Naprawdę nie pozwoli ci używać zmiennych @?