为了账号安全,请及时绑定邮箱和手机立即绑定

无法使用 sequelize 和 mysql 根据包含的模型属性过滤数据

无法使用 sequelize 和 mysql 根据包含的模型属性过滤数据

慕虎7371278 2022-06-09 19:09:16
我有这样的方法:const getAllRequest = async (page, pageSize, order) => {    try {        const requests = await Request.findAndCountAll({            where = {                [Op.or]: [                    sequelize.where(sequelize.col('requests.id'), { [Op.like]: `%${req.query.queryStr}%` }),                    sequelize.where(sequelize.col('requests.user_id'), { [Op.like]: `%${req.query.queryStr}%` }),                    sequelize.where(sequelize.col('requests.uuid'), { [Op.like]: `%${req.query.queryStr}%` }),                    sequelize.where(sequelize.col('requests.status'), { [Op.like]: `%${req.query.queryStr}%` }),                    sequelize.where(sequelize.col('requests.csv_url'), { [Op.like]: `%${req.query.queryStr}%` }),                    sequelize.where(sequelize.col('request_urls.url'), { [Op.like]: `%${req.query.queryStr}%` }),                ]            },            raw: true,            attributes: ['id', 'uuid', 'userId', 'status', 'csvUrl', 'requestURLs.url', 'createdAt', 'updatedAt'],            include: [{                model: RequestUrl,                as: "requestURLs",                where: { type: 'brand' },                attributes: []            }],            subQuery: false,            offset: page * pageSize,            limit: pageSize,            order        });        return {            status: 200,            message: "List of requests.",            requests        }    } catch (error) {        return Promise.reject({            status: 500,            message: "Something went wrong.",            error        });    }}但如果尝试使用包含的模型属性进行过滤,它不会返回数据。相反,它返回:错误:“where 子句”中的未知列“request_urls.url”请帮我解决这个问题。
查看完整描述

2 回答

?
qq_笑_17

TA贡献1818条经验 获得超7个赞

您的where情况应如下 -


 where = {

                [Op.or]: [

                    sequelize.where(sequelize.col('requests.id'), { [Op.like]: `%${req.query.queryStr}%` }),

                    sequelize.where(sequelize.col('requests.user_id'), { [Op.like]: `%${req.query.queryStr}%` }),

                    sequelize.where(sequelize.col('requests.uuid'), { [Op.like]: `%${req.query.queryStr}%` }),

                    sequelize.where(sequelize.col('requests.status'), { [Op.like]: `%${req.query.queryStr}%` }),

                    sequelize.where(sequelize.col('requests.csv_url'), { [Op.like]: `%${req.query.queryStr}%` }),

                    sequelize.where(sequelize.col('requestURLs.url'), { [Op.like]: `%${req.query.queryStr}%` }),

                ]

            },

我希望它有帮助!


查看完整回答
反对 回复 2022-06-09
?
翻阅古今

TA贡献1780条经验 获得超5个赞

注意区别:request_urlsas:"requestURLs"



查看完整回答
反对 回复 2022-06-09
  • 2 回答
  • 0 关注
  • 152 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信