【问题标题】:How to fetch string data stored as array in mysql如何在mysql中获取存储为数组的字符串数据
【发布时间】: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 仅适用于逗号分隔的值,它不能处理数组周围的方括号。

标签: mysql sql node.js json


【解决方案1】:

最好对架构进行规范化,使用多对一表来保存所有唯一字符串,而不是将它们放入单个列中。

但如果您不能这样做,则需要删除 [] 字符,以便使用 FIND_IN_SET()

您还应该使用参数化查询来防止 SQL 注入。见How to create prepared statements in Sequelize?

db.sequelize.query('SELECT * FROM im_vr_client_activation '+
'WHERE FIND_IN_SET(:unique_string, SUBSTR(unique_string, 2, LENGTH(unique_string)-2)) ' +
'AND management_email = :email', {
    replacements: { unique_string: unique_string, email: email }
}).then(...)

如果您使用的是 MySQL 5.7 或更高版本,您可以将列的数据类型更改为 JSON 并使用 JSON_CONTAINS()。而在 8.0 中,您可以使用 MEMBER OF 运算符。

【讨论】:

  • 非常感谢您的快速回复,我已经根据建议更改了我的代码,但是我无法解决问题。请建议我,我该如何解决这个问题?
  • 我对@9​​87654330@ 的参数顺序错误,请立即尝试。
  • 对不起,它不工作,我想一个右括号也漏掉了,在 email: email 请看一下,:email', { replacements: { unique_string: unique_string, email: email }})
  • 该代码仅适用于单个值 "O4hSDDL5hFgqv0Tz" ,不适用于 "BZFeWwnmr8Rm6tuu","daFJWZCEtp2WzxtD","VV80UQQZ1ym77h0m" ,以及 ["BZFeWwnmr8Rm6tuu","daFJWZCEtp2Wzxt7h","UQQZ1ym77h0m""
猜你喜欢
  • 2012-02-17
  • 1970-01-01
  • 2014-02-18
  • 2015-11-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-09-06
相关资源
最近更新 更多