cli*_*uke 16 ruby ruby-on-rails
我正在编写一个与预先存在的系统集成的工资单系统.原始系统有一个处理用户管理和一些全局配置的主数据库,下面有多个数据库,每个数据库在结构上相同,基本上每个数据库都是一个公司工资单数据库,所有这些数据库都绑定到主数据库,因为它属于父数据库公司拥有许多子公司,每个子公司都有自己的人力资
我想知道的是,如果有任何方法可以根据cookie或其他方法存储他们希望连接的公司,可以使用之前的过滤器根据输入动态更改ActiveRecord的目标数据库?
这是一个例子:
用户A登录到站点,页面加载用户有权访问的可用公司,然后用户将选择公司,他们在该公司拥有管理员权限,他们添加员工,在该操作运行之前,rails将切换连接到相应的数据库然后添加记录.
San*_*osh 12
您可以使用ActiveRecord :: Base#establish_connection连接到所需的数据库.
您可以将数据库凭据传递establish_connection给Hash
establish_connection(
adapter: 'mysql2'
encoding: 'utf8'
pool: 5
username: 'me'
password: 'mypassword'
)
Run Code Online (Sandbox Code Playgroud)
还有更多的例子在这里
我不确定你能否在运行时完成它,因为数据库连接已耦合到类(模型)
但是,你可以让不同的类连接到不同的数据库,我不想复制别人的答案,所以只看这篇文章
给他信用
祝好运
| 归档时间: |
|
| 查看次数: |
18646 次 |
| 最近记录: |