Module: MonsterQueries::ActiveRecord
- Extended by:
- ActiveSupport::Concern
- Defined in:
- lib/monster_queries/active_record.rb
Defined Under Namespace
Modules: ClassMethods
Instance Method Summary collapse
- #execute(query) ⇒ Object
- #select_all(query) ⇒ Object
- #select_array(query) ⇒ Object
- #select_json(query, count) ⇒ Object
- #select_object(query) ⇒ Object
- #select_value(query) ⇒ Object
- #select_values(query) ⇒ Object
Instance Method Details
#execute(query) ⇒ Object
5 6 7 8 9 10 11 12 13 |
# File 'lib/monster_queries/active_record.rb', line 5 def execute query begin self.class.connection.execute query rescue File.open(Rails.root.join('tmp','failed.sql'), 'w') { |file| file.write(query) } Rails.root.join raise end end |
#select_all(query) ⇒ Object
58 59 60 |
# File 'lib/monster_queries/active_record.rb', line 58 def select_all query self.class.connection.select_all query end |
#select_array(query) ⇒ Object
41 42 43 44 45 46 47 |
# File 'lib/monster_queries/active_record.rb', line 41 def select_array query sql = " SELECT COALESCE(array_to_json(array_agg(row_to_json(query_row))), '[]'::json)\n FROM (\#{query}) query_row\n SQL\n select_value sql\nend\n" |
#select_json(query, count) ⇒ Object
33 34 35 36 37 38 39 |
# File 'lib/monster_queries/active_record.rb', line 33 def select_json query, count if count select_object query else select_array query end end |
#select_object(query) ⇒ Object
49 50 51 52 53 54 55 |
# File 'lib/monster_queries/active_record.rb', line 49 def select_object query sql = " SELECT COALESCE(row_to_json(query_row),'{}'::json)\n FROM (\#{query}) query_row\n SQL\n select_value sql\nend\n" |
#select_value(query) ⇒ Object
15 16 17 18 19 20 21 22 |
# File 'lib/monster_queries/active_record.rb', line 15 def select_value query begin self.class.connection.select_value query rescue File.open(Rails.root.join('tmp','failed.sql'), 'w') { |file| file.write(query) } raise end end |
#select_values(query) ⇒ Object
24 25 26 27 28 29 30 31 |
# File 'lib/monster_queries/active_record.rb', line 24 def select_values query begin self.class.connection.select_values query rescue File.open(Rails.root.join('tmp','failed.sql'), 'w') { |file| file.write(query) } raise end end |