> 백엔드 개발 > PHP 튜토리얼 > symfony2 doctrine 如何分库分表

symfony2 doctrine 如何分库分表

WBOY
풀어 주다: 2016-06-06 20:49:54
원래의
1557명이 탐색했습니다.

随着数据库表慢慢大起来,想考虑分表。我这边用的是symfony2,所以想问问,symfony2如何分库分表。。。

回复内容:

随着数据库表慢慢大起来,想考虑分表。我这边用的是symfony2,所以想问问,symfony2如何分库分表。。。

先说跑题的一点:

如果数据库支持(如MySQL或者PostgreSQL),建议直接用数据库的partitioning,如果实在不能解决你的需要,在symfony 2里可以:

用事件监听的方式,根据用户ID或其他分库条件,来修改或者动态地注册数据库连接实例。

或者简单点,就自己注册多个连接实例,然后定义一个获取所需实例的helper,比如按用户ID来分库:

<code class="lang-php">// (一)在app/config/config.yml里:
# 定义好各个数据库连接

// (二)在controller里:

private function getManager()
{
    $user = $this->getUser(); // 取得当前用户
    $shardId = null !== $user ? $user->getId() % 4 : 0; // 0,1,2,3共四个库

    return $this->getDoctrine()->getManager(sprintf('shard_%s', $shardId));
}

// (三)在业务Action里:
public function someAction()
{
    $om = $this->getManager(); // 这时拿到的就是对应当前用户的数据库连接实例了

    // ...
}

</code>
로그인 후 복사

在你的业务代码中,你还得考虑分片化后业务的完整性。

和传统的不一样

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿