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 +7 -0
- data/lib/teradata-extractor/connection.rb +15 -0
- data/lib/teradata-extractor/query.rb +47 -0
- data/lib/teradata-extractor.rb +5 -0
- metadata +60 -0
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
|
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: []
|