Class: Lore::Connection

Inherits:
Object
  • Object
show all
Defined in:
lib/lore/connection.rb

Overview

:nodoc

Constant Summary collapse

@@logger =

include Singleton

Lore.logger
@@query_count =
0
@@result_row_count =
0

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeConnection

Returns a new instance of Connection.



91
92
# File 'lib/lore/connection.rb', line 91

def initialize
end

Class Method Details

.perform(query) ⇒ Object



118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
# File 'lib/lore/connection.rb', line 118

def self.perform(query)
  
  begin
    
    connection = Context.get_connection
    
    @@query_count += 1
    result = connection.exec(query)
    @@result_row_count += result.num_tuples
    
    # Log database query on low level: 
    
    if Lore.log_queries? then
      query.split("\n").each { |line|
        @@logger.debug { line }
      }
    end
    
  rescue ::Exception => pge
    
    pge.message << "\n" << query
    @@logger.error { pge.message }
    @@logger.error { 'Context: ' << Context.inspect }
    @@logger.error { 'Query: ' << "\n" << query }
    raise pge
    
  end
  
  return Result.new(query, result)
  
end

.perform_cacheable(query) ⇒ Object



107
108
109
110
111
112
113
114
115
116
# File 'lib/lore/connection.rb', line 107

def self.perform_cacheable(query)
  
  if Lore::Cache::Cached_Entities.include?(query) then
      result = Lore::Cache::Cached_Entities[query]
  else
    result = perform(query)
    Lore::Cache::Cached_Entities[query] = result
  end
  return result
end

.query_countObject



100
101
102
# File 'lib/lore/connection.rb', line 100

def self.query_count
  @@query_count
end

.reset_query_countObject



94
95
96
# File 'lib/lore/connection.rb', line 94

def self.reset_query_count
  @@query_count = 0
end

.reset_result_row_countObject



97
98
99
# File 'lib/lore/connection.rb', line 97

def self.reset_result_row_count
  @@result_row_count = 0
end

.result_row_countObject



103
104
105
# File 'lib/lore/connection.rb', line 103

def self.result_row_count
  @@result_row_count
end