MySQL 5.7.8+ पर आप एक JSON_CONTAINS
प्रत्येक अलग मान के लिए:
SELECT *
FROM Schedule
WHERE ( JSON_CONTAINS(Days, '1')
OR JSON_CONTAINS(Days, '2')
OR JSON_CONTAINS(Days, '6')
)
जब खोजे जाने वाले मान PHP वेरिएबल में संग्रहीत किए जाते हैं - जैसा कि आपके प्रश्न में है - तो आप उपरोक्त SQL को इस तरह बना सकते हैं:
$DaysVar = $_GET['Days'];
$condition = implode(" OR ", array_map(function($day) {
return "JSON_CONTAINS(Days, '$day')";
}, $DaysVar));
$sql = mysqli_query($db, "
SELECT ScheduleID,
Days
FROM Schedule
WHERE ($condition)
");
MySQL 8.*
MySQL 8 के बाद से आप <का उपयोग कर सकते हैं कोड>JSON_OVERLAPS :
SELECT *
FROM Schedule
WHERE JSON_OVERLAPS(Days, '$DaysVar')