Consulta de filtro Mysql basado en entradas de usuario

Mi pregunta anterior no daba una idea clara sobre mi problema, es por eso que estoy haciendo una nueva pregunta.

Aquí está mi estructura de mesa

id, subject (varchar), category(varchar), medium(json), material(json), style(json) 

El usuario puede buscar en función de los valores en los campos de la tabla, es decir, si el usuario elige solo el subject (puede seleccionarlo desde el menú desplegable de selección múltiple) el resultado de la consulta contiene filas que coinciden con los elementos seleccionados.

Si el usuario seleccionó el asunto y el resultado de la consulta de la categoría contiene filas que coinciden con los elementos seleccionados y así sucesivamente (en resumen, es una búsqueda de filtro como sitios web de compras)

El problema es que no entiendo cómo puedo construir de manera eficiente la consulta de MySQL basada en estas entradas porque algunas de las columnas Mysql son JSON.

Aquí está la consulta SQL separada:

 // select rows that contains subject test or test1 SELECT * FROM `cushbu_art` WHERE subject IN ('test','test1') // select rows that contains medium is paper or food SELECT * FROM `cushbu_art` WHERE (JSON_CONTAINS(medium, '["paper"]') OR JSON_CONTAINS(medium, '["food"]')) 

Aquí hay una muestra de entrada con dos parámetros ( subject y medium )

 { "subject":["test","test1"], "medium":["paper","wood"], "category":"", "material":"", "style":"" } 

Nota: la entrada y la salida están en JSON (API REST)

db.js

 function(req, res) { var sql = ''; if(req.body.subject) { sql+=//PREPARE SUBJECT QUERY } if(req.body.medium) { sql+=//PREPARE QUERY } //FINAL SQL QUERY HERE; db.query(sql, function(error, result) { console.log(result); }); } 

 function(req,res){ var sql = 'SELECT * FROM `cushbu_art`'; //Check if only on is set if(req.body.subject && !req.body.medium){ var subjectJoin=req.body.subject.join(','); sql+='WHERE subject IN ('+subjectJoin+')'; } //Check if only on is set if(req.body.medium && !req.body.subject){ sql+='WHERE (JSON_CONTAINS(medium,'+req.body.medium[0]+') OR JSON_CONTAINS(medium,'+req.body.medium[1]+')'; } if(req.body.medium && req.body.subject){ var subjectJoin=req.body.subject.join(','); sql+='WHERE subject IN ('+subjectJoin+') AND (JSON_CONTAINS(medium,'+req.body.medium[0]+') OR JSON_CONTAINS(medium,'+req.body.medium[1]+')'; } //FINAL SQL QUERY HERE'; db.query(sql,function(error,result){ console.log(result); }); }