alf-sql 0.15.0 → 0.16.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/CHANGELOG.md +6 -1
- data/Gemfile.lock +1 -1
- data/lib/alf-sql.rb +1 -1
- data/lib/alf/sql/compiler.rb +7 -1
- data/lib/alf/sql/loader.rb +1 -1
- data/lib/alf/sql/nodes/select_exp.rb +4 -0
- data/lib/alf/sql/nodes/select_list.rb +4 -0
- data/lib/alf/sql/nodes/set_operator.rb +4 -0
- data/lib/alf/sql/nodes/with_exp.rb +2 -1
- data/lib/alf/sql/processor/clip.rb +7 -0
- data/lib/alf/sql/processor/semi_join.rb +19 -11
- data/lib/alf/sql/version.rb +2 -2
- data/spec/helpers/ast.rb +1 -1
- data/spec/nodes/select_exp/test_is_table_dee.rb +22 -0
- data/spec/nodes/select_list/test_is_table_dee.rb +22 -0
- metadata +14 -12
data/CHANGELOG.md
CHANGED
data/Gemfile.lock
CHANGED
data/lib/alf-sql.rb
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
require_relative "alf/sql"
|
|
1
|
+
require_relative "alf/sql"
|
data/lib/alf/sql/compiler.rb
CHANGED
|
@@ -56,7 +56,13 @@ module Alf
|
|
|
56
56
|
end
|
|
57
57
|
|
|
58
58
|
def on_join(plan, expr, left, right)
|
|
59
|
-
|
|
59
|
+
if right.sexpr.is_table_dee?
|
|
60
|
+
rewrite(plan, expr, left, Processor::SemiJoin, [right.sexpr, false])
|
|
61
|
+
elsif left.sexpr.is_table_dee?
|
|
62
|
+
rewrite(plan, expr, right, Processor::SemiJoin, [left.sexpr, false])
|
|
63
|
+
else
|
|
64
|
+
rewrite(plan, expr, left, Processor::Join, [right.sexpr])
|
|
65
|
+
end
|
|
60
66
|
end
|
|
61
67
|
|
|
62
68
|
def on_matching(plan, expr, left, right)
|
data/lib/alf/sql/loader.rb
CHANGED
|
@@ -10,6 +10,13 @@ module Alf
|
|
|
10
10
|
end
|
|
11
11
|
attr_reader :attributes, :on_empty
|
|
12
12
|
|
|
13
|
+
def on_set_operator(sexpr)
|
|
14
|
+
apply(builder.from_self(sexpr))
|
|
15
|
+
end
|
|
16
|
+
alias :on_union :on_set_operator
|
|
17
|
+
alias :on_except :on_set_operator
|
|
18
|
+
alias :on_intersect :on_set_operator
|
|
19
|
+
|
|
13
20
|
def on_select_exp(sexpr)
|
|
14
21
|
catch(:empty){ return super(sexpr) }
|
|
15
22
|
send("select_#{on_empty}", sexpr)
|
|
@@ -24,19 +24,27 @@ module Alf
|
|
|
24
24
|
private
|
|
25
25
|
|
|
26
26
|
def apply_join_strategy(left, right)
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
predicate
|
|
27
|
+
predicate = build_semijoin_predicate(left, right)
|
|
28
|
+
expand_where_clause(left, negate ? !predicate : predicate)
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
def build_semijoin_predicate(left, right)
|
|
32
|
+
if right.is_table_dee?
|
|
33
|
+
right.where_clause.predicate
|
|
34
34
|
else
|
|
35
|
-
|
|
36
|
-
subquery
|
|
37
|
-
|
|
35
|
+
commons = left.to_attr_list & right.to_attr_list
|
|
36
|
+
subquery = Clip.new(commons, :star, builder).call(right)
|
|
37
|
+
if commons.size == 0
|
|
38
|
+
builder.exists(subquery)
|
|
39
|
+
elsif commons.size == 1
|
|
40
|
+
identifier = left.desaliaser[commons.to_a.first]
|
|
41
|
+
Predicate::Factory.in(identifier, subquery)
|
|
42
|
+
else
|
|
43
|
+
join_pre = join_predicate(left, subquery, commons)
|
|
44
|
+
subquery = expand_where_clause(subquery, join_pre)
|
|
45
|
+
builder.exists(subquery)
|
|
46
|
+
end
|
|
38
47
|
end
|
|
39
|
-
expand_where_clause(left, negate ? !predicate : predicate)
|
|
40
48
|
end
|
|
41
49
|
|
|
42
50
|
def expand_where_clause(sexpr, predicate)
|
data/lib/alf/sql/version.rb
CHANGED
data/spec/helpers/ast.rb
CHANGED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
require 'spec_helper'
|
|
2
|
+
module Alf
|
|
3
|
+
module Sql
|
|
4
|
+
describe SelectExp, "is_table_dee?" do
|
|
5
|
+
|
|
6
|
+
subject{ expr.is_table_dee? }
|
|
7
|
+
|
|
8
|
+
context 'when normal select' do
|
|
9
|
+
let(:expr){ select_all }
|
|
10
|
+
|
|
11
|
+
it{ should be_false }
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
context 'when a select is table dee' do
|
|
15
|
+
let(:expr){ select_is_table_dee }
|
|
16
|
+
|
|
17
|
+
it{ should be_true }
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
require 'spec_helper'
|
|
2
|
+
module Alf
|
|
3
|
+
module Sql
|
|
4
|
+
describe SelectList, "is_table_dee" do
|
|
5
|
+
|
|
6
|
+
subject{ expr.is_table_dee? }
|
|
7
|
+
|
|
8
|
+
context 'on a normal select list' do
|
|
9
|
+
let(:expr){ select_list }
|
|
10
|
+
|
|
11
|
+
it{ should be_false }
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
context 'on a is_table_dee select list' do
|
|
15
|
+
let(:expr){ Builder::IS_TABLE_DEE.dup }
|
|
16
|
+
|
|
17
|
+
it{ should be_true }
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
metadata
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: alf-sql
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 0.
|
|
4
|
+
version: 0.16.0
|
|
5
5
|
prerelease:
|
|
6
6
|
platform: ruby
|
|
7
7
|
authors:
|
|
@@ -9,7 +9,7 @@ authors:
|
|
|
9
9
|
autorequire:
|
|
10
10
|
bindir: bin
|
|
11
11
|
cert_chain: []
|
|
12
|
-
date:
|
|
12
|
+
date: 2014-02-18 00:00:00.000000000 Z
|
|
13
13
|
dependencies:
|
|
14
14
|
- !ruby/object:Gem::Dependency
|
|
15
15
|
name: rake
|
|
@@ -44,13 +44,13 @@ dependencies:
|
|
|
44
44
|
- !ruby/object:Gem::Version
|
|
45
45
|
version: '2.14'
|
|
46
46
|
- !ruby/object:Gem::Dependency
|
|
47
|
-
name:
|
|
47
|
+
name: sexpr
|
|
48
48
|
requirement: !ruby/object:Gem::Requirement
|
|
49
49
|
none: false
|
|
50
50
|
requirements:
|
|
51
51
|
- - ~>
|
|
52
52
|
- !ruby/object:Gem::Version
|
|
53
|
-
version: 0.
|
|
53
|
+
version: 0.6.0
|
|
54
54
|
type: :runtime
|
|
55
55
|
prerelease: false
|
|
56
56
|
version_requirements: !ruby/object:Gem::Requirement
|
|
@@ -58,23 +58,23 @@ dependencies:
|
|
|
58
58
|
requirements:
|
|
59
59
|
- - ~>
|
|
60
60
|
- !ruby/object:Gem::Version
|
|
61
|
-
version: 0.
|
|
61
|
+
version: 0.6.0
|
|
62
62
|
- !ruby/object:Gem::Dependency
|
|
63
|
-
name:
|
|
63
|
+
name: alf-core
|
|
64
64
|
requirement: !ruby/object:Gem::Requirement
|
|
65
65
|
none: false
|
|
66
66
|
requirements:
|
|
67
|
-
- -
|
|
67
|
+
- - '='
|
|
68
68
|
- !ruby/object:Gem::Version
|
|
69
|
-
version: 0.
|
|
69
|
+
version: 0.16.0
|
|
70
70
|
type: :runtime
|
|
71
71
|
prerelease: false
|
|
72
72
|
version_requirements: !ruby/object:Gem::Requirement
|
|
73
73
|
none: false
|
|
74
74
|
requirements:
|
|
75
|
-
- -
|
|
75
|
+
- - '='
|
|
76
76
|
- !ruby/object:Gem::Version
|
|
77
|
-
version: 0.
|
|
77
|
+
version: 0.16.0
|
|
78
78
|
description: This project implements an abstract SQL compiler for Alf expressions
|
|
79
79
|
email:
|
|
80
80
|
- blambeau at gmail.com
|
|
@@ -175,8 +175,10 @@ files:
|
|
|
175
175
|
- spec/nodes/order_by_term/test_as_name.rb
|
|
176
176
|
- spec/nodes/order_by_term/test_direction.rb
|
|
177
177
|
- spec/nodes/order_by_term/test_qualifier.rb
|
|
178
|
+
- spec/nodes/select_exp/test_is_table_dee.rb
|
|
178
179
|
- spec/nodes/select_exp/test_order_by_clause.rb
|
|
179
180
|
- spec/nodes/select_item/test_as_name.rb
|
|
181
|
+
- spec/nodes/select_list/test_is_table_dee.rb
|
|
180
182
|
- spec/predicate/nodes/exists/test_not.rb
|
|
181
183
|
- spec/processor/clip/test_on_select_exp.rb
|
|
182
184
|
- spec/processor/clip/test_on_select_list.rb
|
|
@@ -216,7 +218,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
|
216
218
|
version: '0'
|
|
217
219
|
segments:
|
|
218
220
|
- 0
|
|
219
|
-
hash:
|
|
221
|
+
hash: -2896068443355263749
|
|
220
222
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
|
221
223
|
none: false
|
|
222
224
|
requirements:
|
|
@@ -225,7 +227,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
|
225
227
|
version: '0'
|
|
226
228
|
segments:
|
|
227
229
|
- 0
|
|
228
|
-
hash:
|
|
230
|
+
hash: -2896068443355263749
|
|
229
231
|
requirements: []
|
|
230
232
|
rubyforge_project:
|
|
231
233
|
rubygems_version: 1.8.25
|