我用 SQL 编写了以下查询:
Select *
From npt_articles
Inner Join npt_authors
Inner Join users
Inner Join npt_teams
Where npt_teams.id In (1)
以及续集 gem 生成的以下 sql:
SELECT *
FROM `npt_articles`
INNER JOIN `npt_authors`
INNER JOIN `users`
INNER JOIN `npt_teams`
WHERE ('npt_teams.id' IN (1))
第一个返回结果,第二个不返回,如果我删除反引号,那么第二个将生成与第一个相同的结果。
这是生成第二个sql的代码:
team_articles = user.npt_teams.to_a.inject({}) {|arts,team|
arts.merge({ team.name =>
NptArticle.join(:npt_authors).join(:users).join(:npt_teams).where('npt_teams.id' => [team.id]).to_a.uniq})
}
如何生成不带反引号的查询?
最佳答案
你应该尝试这样的事情:
.where(:npt_teams__id => [team.id])
关于mysql - 获取续集生成的sql以生成不带反引号的字段名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37881934/