Module: Csvsql
- Extended by:
- Csvsql
- Included in:
- Csvsql
- Defined in:
- lib/csvsql.rb,
lib/csvsql/version.rb
Defined Under Namespace
Classes: CommandRunner, Db, Tracker
Constant Summary
collapse
- CACHE_DIR =
File.join(Dir.home, '.csvsql_cache')
- VERSION =
"0.2.0"
Class Method Summary
collapse
Instance Method Summary
collapse
Class Method Details
.clear_cache! ⇒ Object
32
33
34
|
# File 'lib/csvsql.rb', line 32
def self.clear_cache!
FileUtils.rm_f(Dir.glob(File.join(CACHE_DIR, '*')))
end
|
Instance Method Details
#execute(sql, csv_data, opts = {}) ⇒ Object
20
21
22
23
24
25
26
27
28
29
30
|
# File 'lib/csvsql.rb', line 20
def execute(sql, csv_data, opts = {})
csvdb = init_data(csv_data, opts)
pst = Csvsql::Tracker.commit(:execute_query_sql) do
csvdb.prepare(sql)
end
Csvsql::Tracker.commit(:output_format)
CSV.generate do |csv|
csv << pst.columns.zip(pst.types).map { |c| c.compact.join(':') }
pst.each { |line| csv << line }
end.tap { Csvsql::Tracker.commit(:output_format) }
end
|