我正在尝试制作一个“通用模型”,以便它可以连接到任何数据库的任何表。首先,我创建了这个连接到另一个指定数据库的类(不使用模式)
D b
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
然后,我创建了这个继承自 Db 并指定表名的类
模型
class Gmodel < Db
def initialize(new_table_name)
ActiveRecord::Base.set_table_name(new_table_name)
super
end
end
最后,在控制器中
主控制器
class MainController < ApplicationController
def index
@users = Gmodel.new("users")
end
end
但是,它给了我这个错误:
undefined method `stringify_keys' for "users":String
有什么问题?有没有更好的方法来做到这一点?提前致谢!