- 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/
上下文:我已经在域根上设置了一个用于 GIS 测试和 dokuwiki 的虚拟机服务器。我想在子域上提供 gis Web 应用程序,这样 dokuwiki url 重命名就不会发生冲突(而且感觉更干净
这个问题在这里已经有了答案: If two variables point to the same object, why doesn't reassigning one variable affe
代码如下: Select Branch.BranchName, Sum(Inventory.OnHand) From Inventory, Branch Inventory.BranchNum = B
我的目标是创建一种“Javascript 库”,如果您可以这样调用它的话。我打算在浏览网页时使用它来操作页面,将其作为 greasemonkey 脚本动态加载。这个想法是将“win”映射到window
是否可以在 javascript 中以某种方式为本地变量分配别名/引用? 我的意思是类似 C 的东西: function foo() { var x = 1; var y = &x; y+
SQLite 别名 您可以暂时把表或列重命名为另一个名字,这被称为别名。使用表别名是指在一个特定的 SQLite 语句中重命名表。重命名是临时的改变,在数据库中实际的表的名称不会改变。 列别名用来
我有以下导入(在同一个 TS 源文件中): import {Vector as sourceVector} from "ol/source"; import {Vector} from "ol/lay
我想弄清楚 this 到底是什么行是在这个 github json 项目的 cmake 文件中, add_library(${NLOHMANN_JSON_TARGET_NAME} INTERFACE)
使用集合时如何创建别名 (AS)。 $collection->addAttributeToSelect('total_qty') 可以这样做: $collection->getSelect()->co
这个问题在这里已经有了答案: Pass an argument to a Git alias command (4 个回答) 去年关闭。 我的团队在不同的分支上工作,通常,我需要快速从分支切换来帮助他
我正在寻找一种向我的 vimrc 添加自定义命令或别名的方法,以便快速切换到 Vim 中的不同目录。我曾经设置过一些东西,但丢失了那个配置。这是用于 Linux 设置。 基本上,我想设置一个别名(如果
我使用 Delphi 和 Firebird 1.5 开发了一个应用程序,其中服务器与应用程序位于同一台计算机上。我现在正在将应用程序部署到另一个站点,其中 Firebird 服务器( super 服务
我创建了一个全新的 React 应用 create-react-app demo 我需要为某些目录/组件创建别名,例如: import { Header } from '@uicomponents'
我正在尝试打印有向图,并且不断更改各种节点属性,例如颜色和形状。有什么方法可以使用一次定义并用于多个节点的变量?理想情况下,我想要这样的东西: digraph g { building_color =
server { listen 80; server_name pwta; root html; location /test/{ alia
我想匹配多个数组,并在匹配时构建另一个数组。该键可以在任意数量的数组中匹配,也可以根本不匹配。 [ [{ 'a': 13 }, { 'b': 62 }, { 'c': 93 }, { 'd': 52
经过审查后,我需要更改一些代码并将所有更改代码重新推送到远程分支上。 所以我想使用别名(例如:git repushall)在 git 上自动化这些不同的命令: git add . git commit
我有一个这样的查询: select a1.name, b1.info from (select name, id, status from table1 a) as a1 righ
我想给一些 racket 2htdp 函数/宏起别名,这样我就可以为我的 child 将它们翻译成另一种语言。 我可以简单地用define给函数起别名。我在使用 big-bang 结构时遇到了麻烦;例
经过审查后,我需要更改一些代码并将所有更改代码重新推送到远程分支上。 所以我想使用别名(例如:git repushall)在 git 上自动化这些不同的命令: git add . git commit
我是一名优秀的程序员,十分优秀!