>我有以下模型:
AuthorModel.hasMany(BookModel);
BookModel.belongsTo(AuthorModel);
有些作者没有书。
我想选择一个作者,其一本书的姓名或标题与搜索字符串匹配。
我可以通过以下语句实现这一点,但仅适用于在他们的 BookModel 中有书籍的作者
Author.findOne({
include: [{
model: Book,
where: {
[Op.or]: [
{'$author.name$': 'search string'},
{ title: 'search string'}
]
},
}]
})
这或多或少给了我以下mysql
查询:
SELECT
`author`.`name`,
`book`.`title`
FROM `author` INNER JOIN `book`
ON `author`.`id` = `book`.`authorId`
AND ( `author`.`name` = 'search string' OR `book`.`title` = 'search string');
这里的问题是,如果一个作者没有书,那么结果是空的。即使有符合搜索条件的作者。
我试图将包含设置为 required: false
,这给出了一个left outer join
。在这种情况下,我得到一些不匹配的结果。省略 where 子句。
我必须如何更改我的sequelize
查询,或者正确的mysql
查询是什么?
MySql 查询可能应该是这样的
SELECT
`author`.`name`,
`book`.`title`
FROM `author` LEFT JOIN `book`
ON `author`.`id` = `book`.`authorId`
WHERE ( `author`.`name` = 'search string' OR `book`.`title` = 'search string')
请注意这里的过滤条件是如何WHERE
而不是JOIN ... ON
子句的一部分
基于顶级的示例,对于急切加载的模型,您的 squizzle 查询可能应该是这样的
Author.findOne({
where: {
[Op.or]: [
{'$author.name$': 'search string'},
{ '$Book.title$': 'search string'}
]
},
include: [{
model: Book,
required: false
}]})