Trên MySQL 5.7.8+, bạn có thể thực hiện JSON_CONTAINS
cho mỗi giá trị riêng biệt:
SELECT *
FROM Schedule
WHERE ( JSON_CONTAINS(Days, '1')
OR JSON_CONTAINS(Days, '2')
OR JSON_CONTAINS(Days, '6')
)
Khi các giá trị cần tìm được lưu trữ trong một biến PHP - như trong câu hỏi của bạn - thì bạn có thể xây dựng SQL ở trên như sau:
$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. *
Kể từ MySQL 8, bạn có thể sử dụng JSON_OVERLAPS
:
SELECT *
FROM Schedule
WHERE JSON_OVERLAPS(Days, '$DaysVar')