У нас есть SQL-запрос, в котором мы используем 3 внутренних соединения и массивно-сложное условие where.У нас есть следующие 4 таблицы:
Таблица 1: Avis - это 1: n к таблице 2 (привязано к Avis.Id = Item.AvisFk)
Таблица 2: Item - это 1: n ктаблица 3 (привязана к Item.Id = Routesection.ItemFk)
Таблица 3: Routesection - это: от 1 до таблицы 4 (привязана к Routesection.TourFk = Tour.Id)
Таблица 4: Тур
Теперь мы используем условие WHERE, где мы фильтруем некоторые даты, местоположения и так далее.Теперь у нас есть проблема, заключающаяся в том, что есть некоторые особые идентификаторы предметов, которые мы не хотим иметь.Мы получаем неправильные результаты.Существуют Avis, которые имеют много предметов.Теперь мы хотим отфильтровать ВСЕ Avis, у которых есть хотя бы один из нежелательных элементов.Но из Tour-Query.
Я попробовал это с WHERE (SELECT Count(*) FROM Item WHERE OemFk=5003 AND AvisFK = Avis.Id) = 0
Но мы должны использовать несколько GROUP BY, и там мы группируем все Avis в один тур. Чтобы мы каждый раз получали «true»,потому что в этом туре есть некоторые Avis, у которых есть нежелательный предмет, а некоторые нет ...
Кто-нибудь знает, как я могу решить эту проблему?
РЕДАКТИРОВАТЬ: Хорошо, я пытаюсьчтобы дать вам основную, что я действительно имею в виду.Допустим, у нас есть 2 строки данных в Avis.Ряды: ID;(только то, что действительно нужно)
1;
2;
Тогда, допустим, у нас есть несколько предметов в Item.Ряды: ID;AvisFk;OemFk;
1; 1; 5001;
2; 1; 5002;
3; 2; 5003;
4; 2; 5004;
Затем Routesection (немного больше строк, я приведу здесь только некоторые для справкипример).Ряды: ID;ItemFk;TourFk;
1; 1; 1;
2; 1; 1;
3; 2; 1;
4; 2; 1;
5; 3; 2;
6; 3; 2;
7; 4; 3;
8; 4; 3;
Наконец, но не в последнюю очередь Тур.Строки: ID;
1;
2;
3;
Хорошо, теперь я хочу запросить таблицу Tour.Результатом должен быть только Тур 1. Желательным результатом было бы получение туров, в которых внутреннее соединение на других таблицах не имеет отношения к специальному условию.Условие таково: если у предмета есть OemFk 5003, тогда ВСЕ предметы, принадлежащие одному и тому же Avis (в данном случае 3 и 4), должны быть отфильтрованы.SELECT ссылается почти на 40 столбцов, а WHERE включает еще 5 условий, и каждый столбец в SELECT также находится внутри GROUP BY, поэтому я попытался показать только необходимый минимум, а не полный запрос.