Я занимаюсь разработкой поискового модуля PHP / MYSQL, в котором мне нужно искать таблицы по многим различным критериям, у меня есть около 11 таблиц, и я использовал несколько объединений для создания одного запроса MySQL и на основе предложения WHERE, которое я намереваюсь для поиска определенных записей, вот запрос MYSQL, который я использую.
SELECT
prop.id,
prop.serial,
prop.title,
prop.rating,
prop.addDate,
prop.approve,
prop.status,
prop.user_id as userId,
user_det.email as email,
user_det.name as name,
prop.area_id as areaId,
area.name as areaName,
area.zipCode as zipCode,
area.city_id as cityId,
city.name as cityName,
city.state_id as stateId,
state.name as stateName,
state.country_id as countryId,
country.name as countryName,
prop.subCategory_id as subCategoryId,
subCat.name as subCategoryName,
subCat.category_id as categoryId,
cat.name as categoryName,
prop.transaction_id as transactionId,
trans.name as transactionName,
price.area as landArea,
price.price as priceSqFt,
price.total_price as totalPrice,
features.bedroom,
features.bathroom,
features.balcony,
features.furnished,
features.floorNum,
features.totalFloor
FROM properties prop
LEFT JOIN user_details user_det ON (prop.user_id = user_det.user_id)
LEFT JOIN areas area ON (prop.area_id = area.id)
LEFT JOIN cities city ON (area.city_id = city.id)
LEFT JOIN states state ON (city.state_id = state.id)
LEFT JOIN countries country ON (state.country_id = country.id)
LEFT JOIN subCategories subCat ON (prop.subCategory_id = subCat.id)
LEFT JOIN categories cat ON (subCat.category_id = cat.id)
LEFT JOIN transactions trans ON (prop.transaction_id = trans.id)
LEFT JOIN prop_prices price ON (price.property_id = prop.id)
LEFT JOIN prop_features features ON (features.property_id = prop.id)
, хотя здесь все работает хорошо, у меня есть ситуация, когда у меня есть таблица с именем prop_amenities
, приведенная ниже. Содержимое этой таблицы.

, поскольку в приведенной выше таблице есть несколько property_id
, если я запрашиваю его, используя JOINS, то в основном он будет возвращать повторяющиеся записи или одну запись, исключая другие в зависимости от типа JOIN
, который я использую. поэтому вместо этого я хотел бы разобраться с этим так.
используйте таблицу prop_aferences, чтобы иметь дело только с условиями, чтобы не возвращать результат.
например, я ищу свойство с идентификатором удобства 1,5,9,17 и 24, затем он должен проверить, существуют ли все записи в таблице prop_amenities
, то есть 1,5,9,17 и 24 в этом случае , и вернуть соответствующие записи со всеми выбранными выше столбцами.
Я не знаю, как справиться с этой ситуацией, используя MySQL. как мне это сделать?
спасибо ..