如何解决使用hasMany关联条件对查询进行排序
我在Sequelize Operation
和File
中有两个模型,它们具有以下关系:
Operation.hasMany(File,{
foreignKey: 'attachedTo',sourceKey: 'id',constraints: false,as: 'files'
});
在Operation
和File
型号上,我都有一个createdBy
列。我想查询所有没有文件的操作,或者所有不是由创建操作的人创建的文件。
这是我到目前为止所拥有的:
Operation.findAll({
include: [
{ model: File,as: 'files',required: false,attributes: [] },],where: {
[Op.or]: [
{ '$files.createdBy$': { [Op.ne]: Sequelize.col('Operation.createdBy') } },{ '$files.key$': { [Op.eq]: null } },]
}
});
在没有文件或由创建操作的同一人创建的所有文件的情况下,此方法有效。如果创建该操作的同一人和其他人创建了混合文件,则它将返回我们不想要的操作记录。如何告诉Sequelize,如果创建操作的人至少创建了一个文件,则该记录应被丢弃?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。