I'm trying to make a "generic model" so it can connect to any table of any database. First, I made this class which connects to another database specified (not using the schema)
Db
class Db < ActiveRecord::Base self.abstract_class = true attr_accessor :error def initialize(item = nil) @error = "" connect super end def connect could_connect = true @error = "" begin ActiveRecord::Base.establish_connection( :adapter => "mysql2", :host => "localhost", :username => "root", :password => "", :database => "another_database", :port => 3306, :encoding => "utf8" ) rescue ActiveRecord::ConnectionNotEstablished @error = "Could not connect to database. The connection was not established" could_connect = false rescue Mysql2::Error @error = "Could not connect to database using MySQL2" could_connect = false rescue => e @error = "Could not connect to database. #{e.message}." could_connect = false end return could_connect end end
Then, I made this class which inherits from Db and specifies the table name
Gmodel
class Gmodel < Db def initialize(new_table_name) ActiveRecord::Base.set_table_name(new_table_name) super end end
Finally, in the controller
MainController
class MainController < ApplicationController def index @users = Gmodel.new("users") end end
But, it gaves me this error:
undefined method `stringify_keys' for "users":String
What could be wrong? Is there some better way to do this? Thanks in advance!