gpt4 book ai didi

symfony - 在 Symfony2 中使用 2 个数据库和一个实体管理器

转载 作者:行者123 更新时间:2023-12-01 12:39:43 24 4
gpt4 key购买 nike

我需要为 Symfony2 中的应用程序保留一个存档数据库。我将在其中保留所有超过 90 天的记录。我在想我可以只使用一个实体管理器(因为两个数据库是相同的)。

首先,我不确定这是否是最佳方法/解决方案。而且,除此之外,我不知道如何实现这个想法(我刚刚为 2 个数据库找到了 2 个实体管理器)。

如果这是一个愚蠢的问题,我很抱歉,但我已经为它寻找了 2 天的解决方案。

最佳答案

我们使用不同的 em 来保存历史记录,效果很好。代码如下所示。

某处在您的配置中...

你的路径\app\config\parameters.yml

parameters:
database_driver: pdo_mysql
database_host: site1.ru
database_port: 3346
database_name: db1
database_user: roof
database_password: jump

database_history_driver: pdo_mysql
database_history_host: site2.ru
database_history_port: 10001
database_history_name: history
database_history_user: sea
database_history_password: deep

etc...

某处在您的历史包中...

/**
* We make history!
**/
class historyController extends Controller
{
public function showAction($historyId)
{
// get secondary manager
$emHistory = $this->getDoctrine()->getManager('history');
// get default manager
$em = $this->getDoctrine()->getManager('default');
}
}

历史包服务中的某处

class HistoryBundleUtils {
protected $em;

public function __construct($arguments) {
// get secondary manager
$this->em = $arguments['entityManager']->getManager('history');
# etc...
}
}

关于symfony - 在 Symfony2 中使用 2 个数据库和一个实体管理器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26132582/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com