9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
# File 'lib/bigshift/redshift_unloader.rb', line 9
def unload_to(table_name, s3_uri, options={})
table_schema = RedshiftTableSchema.new(table_name, @redshift_connection)
credentials_string = "aws_access_key_id=#{@aws_credentials.access_key_id};aws_secret_access_key=#{@aws_credentials.secret_access_key}"
select_sql = 'SELECT '
select_sql << table_schema.columns.map(&:to_sql).join(', ')
select_sql << %Q< FROM "#{table_name}">
select_sql.gsub!('\'') { |s| '\\\'' }
unload_sql = %Q<UNLOAD ('#{select_sql}')>
unload_sql << %Q< TO '#{s3_uri}'>
unload_sql << %Q< CREDENTIALS '#{credentials_string}'>
unload_sql << %q< MANIFEST>
unload_sql << %q< DELIMITER '\t'>
unload_sql << %q< GZIP> if options[:compression] || options[:compression].nil?
unload_sql << %q< ALLOWOVERWRITE> if options[:allow_overwrite]
@logger.info(sprintf('Unloading Redshift table %s to %s', table_name, s3_uri))
@redshift_connection.exec(unload_sql)
@logger.info(sprintf('Unload of %s complete', table_name))
end
|