raka 0.3.15 → 0.3.17
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/VERSION +1 -1
- data/lib/raka/lang/psql/impl.rb +6 -6
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 8bd8a3909d7c65928115e4079d42947c46c3295dfbd7570fc4d861ad3855719b
|
4
|
+
data.tar.gz: 95b995c5f8fdcddf2f14cd3aab2d1c36bc1ae07ff579f77eeaa1e5dae8d775dc
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1260dc630ecd9d31b710898f5c61ed153c85578ab68c0d73a0d690d51b005211aac68159cac937ec33a5706161257963abda14c25d2cf768b84ccf33c6258d55
|
7
|
+
data.tar.gz: bb2f0737226b1988f2655f2ad7b464a3ec0031b7608262a8681fa28f31d6c353d5930dab32d69771f6bcbadf8838f4f4dd7e11c0a21cc9ba6c7effdcb38a1b7e
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.3.
|
1
|
+
0.3.17
|
data/lib/raka/lang/psql/impl.rb
CHANGED
@@ -24,10 +24,9 @@ class Psql
|
|
24
24
|
end
|
25
25
|
|
26
26
|
# 1. do not add required argument here, so psql.config will work or we can only use psql(conn: xxx).config
|
27
|
-
def initialize(conn: nil, create: 'mview',
|
27
|
+
def initialize(conn: nil, create: 'mview', params: {})
|
28
28
|
@create = create
|
29
29
|
@params = params
|
30
|
-
@schema = schema
|
31
30
|
@conn = conn
|
32
31
|
end
|
33
32
|
|
@@ -37,10 +36,10 @@ class Psql
|
|
37
36
|
|
38
37
|
if @create.to_s == 'table'
|
39
38
|
'DROP TABLE IF EXISTS :_schema_:_name_;' \
|
40
|
-
'CREATE TABLE :
|
39
|
+
'CREATE TABLE :_schema_:_name_ AS (' + code + ');'
|
41
40
|
elsif @create.to_s == 'mview'
|
42
41
|
'DROP MATERIALIZED VIEW IF EXISTS :_schema_:_name_;' \
|
43
|
-
'CREATE MATERIALIZED VIEW :
|
42
|
+
'CREATE MATERIALIZED VIEW :_schema_:_name_ AS (' + code + ');'
|
44
43
|
else
|
45
44
|
code
|
46
45
|
end
|
@@ -48,11 +47,12 @@ class Psql
|
|
48
47
|
|
49
48
|
def run_script(env, fname, task)
|
50
49
|
param_str = (@params || {}).map { |k, v| "-v #{k}=\"#{v}\"" }.join(' ')
|
51
|
-
schema =
|
50
|
+
schema = task.rule_scopes.join('__')
|
51
|
+
out_schema = (task.rule_scopes + (task.target_scope.nil? ? [] : [task.target_scope])).join('__')
|
52
52
|
|
53
53
|
bash env, %(
|
54
54
|
#{sh_cmd(schema)} #{param_str} -v _name_=#{task.output_stem} \
|
55
|
-
-v _schema_=#{
|
55
|
+
-v _schema_=#{out_schema.empty? ? '' : out_schema + '.'} -f #{fname} | tee #{fname}.log
|
56
56
|
mv #{fname}.log #{task.name}
|
57
57
|
)
|
58
58
|
end
|