teradata-extractor 0.0.1-java

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: dc1605ba0ce422344ee9cd948774d41700031622
4
+ data.tar.gz: 925e49abf0c96ae9660dc8cfedbb3b3a7424dc1b
5
+ SHA512:
6
+ metadata.gz: a4ecb227dda8ac886d8e6ad88609f45441ba8d19484372ddce218b3a26b2d184597090153a85858965f432168e944cc9304b58c2d3fe233a73719000caf9cfed
7
+ data.tar.gz: 070d7c9680400e5552ec39f1cd13f5d94d45fe45e3059d2add7e618043cc6cd3996a8a84c1142e3b2c63fe7b004b817e95f1c1dfc865964ed8a84a587f9d139c
@@ -0,0 +1,15 @@
1
+ require 'singleton'
2
+ require 'jdbc/teradata'
3
+
4
+ module TeradataExtractor
5
+ class Connection
6
+ include Singleton
7
+
8
+ def connection(server_name, username, password)
9
+ Jdbc::Teradata.load_driver
10
+ import Java::com.teradata.jdbc.TeraDriver
11
+ teradataurl = "jdbc:teradata://#{server_name}/CHARSET=UTF8,TMODE=ANSI"
12
+ java.sql.DriverManager.get_connection(teradataurl, username, password)
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,47 @@
1
+ require 'csv'
2
+
3
+ module TeradataExtractor
4
+ class Query
5
+
6
+ # @param [com.teradata.jdbc.jdk6.JDK6_SQL_Connection] Teradata connection
7
+ # @param [#to_s] sql Sql query to execute
8
+ def initialize(server_name, username, password)
9
+
10
+ @connection = TeradataExtractor::Connection.instance.connection(server_name, username, password)
11
+ @statement ||= @connection.create_statement
12
+ end
13
+
14
+ def to_enumerable(sql)
15
+ results = @statement.execute_query(sql)
16
+ #results = conn.execute_query("select TOP 10 country_id, sf_account_id, country_name from emea_analytics.eu_deal_flat")
17
+ e = Enumerator.new do |y|
18
+ column_count = results.getMetaData.getColumnCount;
19
+ while(results.next) do
20
+ row = {}
21
+ 1.upto(column_count) do |i|
22
+ column_name = results.getMetaData.getColumnName(i).to_sym
23
+ row[column_name] = results.getObject(i)
24
+ end
25
+ y << row
26
+ end
27
+ end
28
+ end
29
+
30
+ def to_csv(sql)
31
+ results = @statement.execute_query(sql)
32
+ #results = conn.execute_query("select TOP 10 country_id, sf_account_id, country_name from emea_analytics.eu_deal_flat")
33
+ CSV.generate do |csv|
34
+ column_count = results.getMetaData.getColumnCount;
35
+ csv << 1.upto(column_count).map{|i| results.getMetaData.getColumnName(i)}
36
+
37
+ while(results.next) do
38
+ row = []
39
+ 1.upto(column_count) do |i|
40
+ row << results.getObject(i)
41
+ end
42
+ csv << row
43
+ end
44
+ end
45
+ end
46
+ end
47
+ end
@@ -0,0 +1,5 @@
1
+ require 'rubygems'
2
+ require 'teradata-extractor/connection'
3
+ require 'teradata-extractor/query'
4
+ require 'rails'
5
+
metadata ADDED
@@ -0,0 +1,60 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: teradata-extractor
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: java
6
+ authors:
7
+ - Steve Mitchell
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-02-10 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: jdbc-teradata
15
+ version_requirements: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - '>='
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ requirement: !ruby/object:Gem::Requirement
21
+ requirements:
22
+ - - '>='
23
+ - !ruby/object:Gem::Version
24
+ version: '0'
25
+ prerelease: false
26
+ type: :runtime
27
+ description: Get your data from Teradata AND GET TO THE CHOPPER!
28
+ email: thestevemitchell@gmail.com
29
+ executables: []
30
+ extensions: []
31
+ extra_rdoc_files: []
32
+ files:
33
+ - lib/teradata-extractor.rb
34
+ - lib/teradata-extractor/connection.rb
35
+ - lib/teradata-extractor/query.rb
36
+ homepage: http://github.com/theSteveMitchell/teradata-extractor
37
+ licenses:
38
+ - MIT
39
+ metadata: {}
40
+ post_install_message:
41
+ rdoc_options: []
42
+ require_paths:
43
+ - lib
44
+ required_ruby_version: !ruby/object:Gem::Requirement
45
+ requirements:
46
+ - - '>='
47
+ - !ruby/object:Gem::Version
48
+ version: '0'
49
+ required_rubygems_version: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - '>='
52
+ - !ruby/object:Gem::Version
53
+ version: '0'
54
+ requirements: []
55
+ rubyforge_project:
56
+ rubygems_version: 2.1.9
57
+ signing_key:
58
+ specification_version: 4
59
+ summary: A pretty thin wrapper around the jdbc-teradata driver that encapsulates the ugly java bits and gives you back a nice ruby enumerable
60
+ test_files: []