SELECT SQL_CALC_FOUND_ROWS suisse_sites.*, categoryId, packageId, 0 as isNew FROM suisse_sites WHERE status = 'validated' AND ((MATCH (siteTitle, description) AGAINST ('+participation +a +eurosic +et +lsv +bdd +en +tant +que +deb +ef' IN BOOLEAN MODE)) AND (address like '%b%' OR description like '%b%' OR city like '%b%')) AND 1=1 UNION DISTINCT ( select suisse_sites.*, categoryId, packageId, 0 as isNew from suisse_sites INNER JOIN suisse_keywordsofsites ON suisse_keywordsofsites.siteId = suisse_sites.siteId INNER JOIN suisse_keywords ON suisse_keywords.keywordId = suisse_keywordsofsites.keywordId where status = 'validated' and suisse_keywords.keyword IN ('participation','a','eurosic','et','lsv','bdd','en','tant','que','deb','ef') AND (address like '%b%' OR suisse_sites.description like '%b%' OR suisse_sites.city like '%b%') ) ORDER BY priority DESC, creationDate DESC LIMIT 30 OFFSET 60