postgres_with 3.0.0 → 3.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/postgres_with/arel/visitors/to_sql.rb +25 -0
- data/lib/postgres_with/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: b501852be5081b6ecee9e02f9acfa8117daaf3c41b3b80adcfa890bdb89684d6
|
4
|
+
data.tar.gz: 3d96bd9e0c9c260188c98448ce39a803d2a8cd4f8773c58d10887046611f50a9
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 6931ede70fc5f17be0bc510e09bb331c45f92057c2305d73411dcc55f9166bb22aeebdb2648763b6254f5bf1eeec5ceb1feba84c9e6b06fcc89e482c8117cf87
|
7
|
+
data.tar.gz: 1097366d74ad84680de6c40984bebeca11a569b59ce2c3bf220cb3eb10600ea88d0757964736f81e1aa8337f4e58b35fd1237f29eea8ed11e94de0b9d2a29c43
|
@@ -6,6 +6,31 @@ module Arel
|
|
6
6
|
collector << " AS MATERIALIZED "
|
7
7
|
visit o.right, collector
|
8
8
|
end
|
9
|
+
|
10
|
+
def collect_ctes(children, collector)
|
11
|
+
children.each_with_index do |child, i|
|
12
|
+
collector << ", " unless i == 0
|
13
|
+
|
14
|
+
case child
|
15
|
+
when Arel::Nodes::As, Arel::Nodes::AsMaterialized
|
16
|
+
name = child.left.name
|
17
|
+
relation = child.right
|
18
|
+
when Arel::Nodes::TableAlias
|
19
|
+
name = child.name
|
20
|
+
relation = child.relation
|
21
|
+
end
|
22
|
+
|
23
|
+
collector << quote_table_name(name)
|
24
|
+
if child.class == Arel::Nodes::AsMaterialized
|
25
|
+
collector << " AS MATERIALIZED "
|
26
|
+
else
|
27
|
+
collector << " AS "
|
28
|
+
end
|
29
|
+
visit relation, collector
|
30
|
+
end
|
31
|
+
|
32
|
+
collector
|
33
|
+
end
|
9
34
|
end
|
10
35
|
end
|
11
36
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: postgres_with
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.0.
|
4
|
+
version: 3.0.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Derrick Neier
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-
|
11
|
+
date: 2023-06-27 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|