在where子句中传递动态查询时未处理的拒绝SequelizeDatabaseError

时间:2019-05-06 20:17:15

标签: javascript mysql express sequelize.js

我正在尝试分解用户的get请求,并将其放入名为query的变量中。然后使用where子句将var查询传递到sequelize的findAll方法中,似乎Sequelize认为我实际上在尝试传递对象时正在寻找表CALLED查询。很抱歉,如果我无法很好地解释,但这是代码和错误:

var info = [];
//link example: localhost:8081/filter/?descripiton=san+francisco&houseType=house&numOfBedroom=3&numOfBathroom=2&houseSize=500&price=1200
exports.filterListings = function(req) {
    //create an object literal which we will return, and has a nested object named filteredList inside.
    //filteredList contains an array named listings where we will put listings that match our filter inside
    let response = {
        filteredList: {listings: []},
    };

    //now we need to see how the user wants us to filter the listings
    const query = req.query;
    //do some logic where we decompose query

    if(query.descripiton != undefined) {
    //info = info + 'descripiton: ' + query.descripiton+', ';
    info.push('descripiton: ' + query.descripiton+', ');
    console.log(info);
    }
    if(query.houseType != undefined) {
    //info = info + 'houseType: ' + query.houseType+', ';
    info.push('houseType: ' + query.houseType+', ');
    //console.log(info);
    }
    if(query.numOfBedroom != undefined) {
    //info = info + 'numOfBedroom: ' + query.numOfBedroom+', ';
    info.push('numOfBedroom: ' + query.numOfBedroom+', ');
    }
    if(query.numOfBathroom != undefined) {
    //info = info + 'numOfBathroom: ' + query.numOfBathroom+', ';
    info.push('numOfBathroom: ' + query.numOfBathroom+', ');
    }
    if(query.houseSize != undefined) {
    //info = info + 'houseSize: ' + query.houseSize+', ';
    info.push('houseSize: ' + query.houseSize+', ');
    }
    if(query.price != undefined) {
    //info = info + 'price: ' + query.price;
    info.push('price: ' + query.price);
    }

然后当我尝试传递信息变量

listingModel.findAll({
        //error because it wont recognize the variable search nor will it recognize info
        where: {info}
    }).then(listings => {
        // so we loop through listings and insert what we have found into the response (which we are going to return)
    for(var i = 0; i < listings.length; i++) {
        response.filteredList.listings.push(listings[i]);
    }; // loop where we insert data into response done

我希望它根据动态查询查找所有列表,但出现错误:

Unhandled rejection SequelizeDatabaseError: Unknown column 'Listing.info' in 'where clause'

非常感谢您的潜在帮助!

1 个答案:

答案 0 :(得分:0)

让我们尝试一次对您的问题进行排序。双关语很抱歉:p

不要使用多个if来创建过滤列表。使用for ... in。然后将对象数组与Sequelize.Op一起使用来创建查询。

示例:

const Op = require('sequelize').Op;

const whereClause = [];
const query = req.query;
for(const key in query) {
  if(query[key] !== '' && query[key] !== null) {
    //object will be pushed to the array like "houseType:big"
    whereClause.push({key:query[key]})
  }
}

//you now have the where clause
//use it in your query with Op.and

listingModel.findAll({
  where: {
    [Op.and]: whereClause,
  }
});

有关使用Sequelize - Operators查询的更多信息