4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
# File 'lib/loader/vertica/vertica_sql.rb', line 4
def self.create_table_stmt options
sql = "CREATE TABLE IF NOT EXISTS #{options[:vertica_db]}."
sql += "#{options[:vertica_schema]}." if options[:vertica_schema]
sql += "#{options[:table]} ("
index = 1
options[:columns].each do |column|
sql += "\"#{column['column_name']}\" "
sql += data_type(column['data_type'], column['column_type'])
sql += " "
sql += nullable(column['is_nullable'])
sql += " "
if index < options[:columns].size
sql += ", "
end
index += 1
end
primary_set = false
options[:columns].each do |column|
if column['column_key'] == "PRI"
if !primary_set
sql += ", PRIMARY KEY (" + "\"#{column['column_name']}\" "
else
sql += ", " + "\"#{column['column_name']}\" "
end
primary_set = true
end
end
if primary_set
sql += ") "
end
options[:columns].each do |column|
if column['column_key'] == "UNI"
sql += ", UNIQUE (" + "\"#{column['column_name']}\" "
sql += ") "
end
end
sql += ");"
puts sql
return sql
end
|