teradata-extractor 0.0.1-java

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.
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: []