- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 RAILS 4 和 MySQL服务通过服务场所有很多场所。
我正在尝试创建一个与以下 SQL 查询等效的 AREL:
SELECT DISTINCT
services . *
FROM
services
INNER JOIN
(SELECT DISTINCT
`services` . *
FROM
`services`
LEFT OUTER JOIN `service_places` ON `service_places`.`service_id` = `services`.`id`
WHERE
`service_places`.`place_id` IN (SELECT DISTINCT
`places`.`id`
FROM
`places`
WHERE
(`places`.`place_name` LIKE '%war%'))) s1 ON s1.id = services.id
INNER JOIN
(SELECT DISTINCT
`services` . *
FROM
`services`
LEFT OUTER JOIN `service_places` ON `service_places`.`service_id` = `services`.`id`
WHERE
`service_places`.`place_id` IN (SELECT DISTINCT
`places`.`id`
FROM
`places`
WHERE
(`places`.`place_name` LIKE '%leam%'))) s2 ON s2.id = services.id;
理想情况下,这将通过插入查询来完成,但在阅读了一些资料后,我发现尽管 AREL 提供了 INTERSECT,但 MySql 不支持它。所以我使用连接创建了 SQL,它返回我期望的数据。
我有一些 AREL 代码来创建两个子查询并且工作正常:
s = Service.arel_table
sp = ServicePlace.arel_table
p = Place.arel_table
search_from = "leam"
search_to = "war"
############
# From QUERY
############
from_subquery = Place.select(p[:id]).where(p[:place_name].matches("%#{search_from}%")).uniq
from_query = Service.joins(
s.join(sp, Arel::Nodes::OuterJoin).on(sp[:service_id].eq(s[:id]))
.join_sql
).uniq
from_query = from_query.where(sp[:place_id].in(from_subquery.ast))
##########
# To Query
##########
to_subquery = Place.select(p[:id]).where(p[:place_name].matches("%#{search_to}%")).uniq
to_query = Service.joins(
s.join(sp, Arel::Nodes::OuterJoin).on(sp[:service_id].eq(s[:id]))
.join_sql
).uniq
to_query = to_query.where(sp[:place_id].in(to_subquery.ast))
我的问题在于尝试创建包含这两个子查询的 AREL 查询。我试过了,但失败了:
query = Service.joins(from_subquery.as('s1')).on(s1[:id].eq(s[:id]))
.join(to_subquery.as('s2')).on(s2[:id].eq(s[:place_id]))
.join_sql
).uniq
NameError: undefined local variable or method `s1' for main:Object
我很高兴我构建它的方式是好的,因为我有一个类似的语法查询正在运行并且没有问题(见下文):
query = Service.joins(
s.join(sp, Arel::Nodes::OuterJoin).on(sp[:service_id].eq(s[:id]))
.join(p, Arel::Nodes::OuterJoin).on(p[:id].eq(sp[:place_id]))
.join_sql
).uniq
我知道问题在于我如何引用关系中的子查询,但不知道这是什么。我已经看到对“create_table_alias”、“alias”和“as”方法的引用,但找不到任何对我有帮助的示例。这可能是一些非常明显的东西,一如既往,我只是看不到它。
如果有人能提供帮助,我将不胜感激。
提前致谢。
更新 01:
我找到了一个 AREL syntax creator http://www.scuttle.io/这对于生成 AREL 语法很有用。它对我完全不起作用,但对于较小的 block 它会。您需要将“喜欢”更改为“=”,因为它不包括它们。不过,您之后可以将“eq”改回“matches”。
更新 02:
尝试将 CTE 与创建 Arel::SelectManager 对象的代码结合使用。然而,进一步的研究表明您不能在 MYSQL 中使用 CTE。作为引用,我使用的代码如下所示。
cte_table = Arel::Table.new(:cte_table)
composed_cte = Arel::Nodes::As.new(cte_table, from_query)
s.join(cte_table).on(s[:id].eq(cte_table[:id])).project(s[Arel.star]).with(composed_cte)
最佳答案
as
在 Arel 中主要用于为 SELECT
子句中的特定字段指定名称(粗略地说,在 Arel 中显示为 project
) , 表别名通常以不同的方式处理。
问题在于,在您的工作示例中,您使用不涉及别名的表对象 构建了子查询。但是要在 SQL 中为该表添加别名,而不是表对象,您需要从表对象生成的别名表对象。这听起来可能比实际情况更复杂。
给定一个别名表,您几乎可以在任何地方使用它而不是表本身。
p = Place.arel_table # Actual table
pa = p.alias # Table alias
# Use an actual table object just as an entry point to Arel, not sure if necessary
from_subquery = p.
# Now use an alias (the name `pa` will likely be different, as it is chosen by Arel,
# but should be the same for the same alias object):
# SELECT pa.id FROM pa
project(pa[:id]).from(pa).
where(
pa[:place_name].matches("%#{search_from}%") # Use alias for condition
).uniq
完成后,您可以在该子查询中使用相同的对象 pa
引用该别名。
这是一个基本示例,大致基于 arel README , 但它显示了消除错误所需的内容:这样您就可以将别名表对象放入您的范围并能够自由使用它。
关于mysql - 如何在 AREL 查询中使用别名引用子查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27319623/
我在看 : 有关列出哪些方法可用的引用文档? 关于如何设置和执行查询,然后构建复杂查询的教程? 检查自述文件,这里被标记为 Arel 的问题,但大多数是关于如何设置 where 子句,复杂的查询而不是
一个模型有两个感兴趣的属性,名字和城镇。我想搜索 Richard(伦敦)和 Brian(马德里)。 从长远来看, p=Person.scoped pred1=p.table[:forename].eq
让我们有一个 Rails 4.2.x 应用程序,我们有两个表 posts 和 authors,我们想使用 Arel 来获取由 name == 'Karl' 的作者创作的帖子。 (在这种情况下,我们可以
我正在尝试重构一段代码(并提高我对 Arel::Nodes::Case 的理解),我想转换此 Arel.sql 语句 Arel.sql(default_order) def defau
我正在使用 Arels 创建查询。在此查询中,我使用了 generate_series 函数。这是我的代码: def generate_series Arel::Nodes::Na
我有这个用例,我从某个模型中获得符号化的深层关联,并且我必须执行某些涉及使用外连接的查询。如何在不求助于手动编写完整 SQL 的情况下做到这一点? 我不想要的答案: - 使用包含(不能很好地解决深层关
我正在尝试使用 ARel 清理用 MySQL case 语句编写的 ActiveRecord 代码。我知道 Arel 能够处理 case 语句,但不确定如何使用它。 所以我有一个带有数量和 user_
我需要一个消息列表,其中每条消息都是当前用户与其他用户之间“对话”中的最新消息。 描述了相同的查询 in this question 我目前的代码是: t1 = Arel::Table.new(:me
我正在尝试使用 Arel#extract 方法。我在源代码中的 test_extract.rb 中的测试用例中看到了一个示例,但是当我尝试在我的应用程序中重现它时,我得到了未定义的方法。 table
我在使用 Arel 聚契约(Contract)一查询中的 2 列时遇到了问题。当我运行它时,在 rails dev-server 崩溃之前,整个服务器会卡住一分钟。我怀疑是无限循环:)。 也许我误解了
我有以下 Arel SQL: Arel.sql("(users.last_donated_at IS NOT NULL AND users.last_donated_at < '#{User::ACT
假设我有几张 table orders = Arel::Table.new :orders stores = Arel::Table.new :stores managers = Arel::Tabl
我有以下内容: class BaseReseller :merchant_owner, :dependent => :destroy end class IPSP true end class M
如果您使用 joins在 ARel 范围内,结果变为只读(即您无法更新您返回的任何记录)。如果您不希望结果是只读的,您只需链接 readonly(false)到范围,例如 User.joins(:or
我有一个 fairly complex sql query我很确定我无法使用 ARel (Rails 3.0.10) 来完成 查看该链接,但它有一些连接和一个 where isn't 子句,我很确定这
我正在尽最大努力让我的大脑围绕阿雷尔及其背后的关系代数进行思考,但如何表示SELECT DISTINCT始终让我无法理解。谁能解释一下如何设置: SELECT DISTINCT title FROM
我正在尝试抽象出有人插入我们代码库的原始 sql 主体,我们使用的是 Rails 4.2.8。我想要生成以 where 子句结尾的 sql,如下所示: WHERE col1=1 OR col2=1 O
我试图寻找一个使用 Arel::UpdateManager 来形成带有 from 子句的更新语句的示例(如 UPDATE t SET t.itty = "b"FROM .. .. WHERE ...)
我想向 Arel 添加额外的列选择结果,其中列中的值在每一行上都相同,以便我可以向 Rails ActiveRecord 对象添加有关查询上下文的额外信息。 那么,我如何使用 Arel 生成此 SQL
我正在使用 RAILS 4 和 MySQL服务通过服务场所有很多场所。 我正在尝试创建一个与以下 SQL 查询等效的 AREL: SELECT DISTINCT services . * FR
我是一名优秀的程序员,十分优秀!