【发布时间】:2019-09-13 08:10:40
【问题描述】:
我已经在 MySQL 中存储了一些与用户电子邮件相关的唯一代码作为数组,现在我想通过用户提交的电子邮件和唯一代码来验证用户。我想创建一个查询,我可以在其中匹配存储在数据库中的电子邮件和唯一 ID,以继续用户。
数据库入口:
["BZFeWwnmr8Rm6tuu","daFJWZCEtp2WzxtD","VV80UQQZ1ym77h0m"]
我试过 FIND_IN_SET
这是 API 的代码,我已经对用户输入的数据进行了字符串化,如果存储了单个唯一值,它将返回该值,但是如果我获取唯一代码数组,例如 ["BZFeWwnmr8Rm6tuu","daFJWZCEtp2WzxtD","VV80UQQZ1ym77h0m"]
MySQL 查询不工作。
exports.vr_client_detail = function (req, res) {
const JSON_DATA = 'application/json';
if(req.headers['content-type'] === JSON_DATA){
if (req.body) {
var unique_string = JSON.stringify(req.body.unique_string);
var email = req.body.management_email;
db.sequelize.query('SELECT * FROM im_vr_client_activation '+
'WHERE FIND_IN_SET(unique_string, '+"'"+unique_string+"') AND "+
' management_email= ' + "'" + email + "'").then(function(app){
var arr = app[0];
return res.json({response_status:'success', response_code:185, data:arr, response:'Successfully fetch data.'})
});
}else{
return res.json({response_status:'error',response_code:10001,response:'Post data is empty.'});
}
}else{
return res.json({response_status:'error',response_code:10000,response:'Post data is not a json type.'});
}
}
数据不返回任何内容
{
"response_status": "success",
"response_code": 185,
"data": [],
"response": "Successfully fetch data."
}
【问题讨论】:
-
FIND_IN_SET仅适用于逗号分隔的值,它不能处理数组周围的方括号。