symfony2 doctrine 如何分库分表
程序员文章站
2024-01-04 16:08:22
...
随着数据库表慢慢大起来,想考虑分表。我这边用的是symfony2,所以想问问,symfony2如何分库分表。。。
回复内容:
随着数据库表慢慢大起来,想考虑分表。我这边用的是symfony2,所以想问问,symfony2如何分库分表。。。
先说跑题的一点:
如果数据库支持(如MySQL或者PostgreSQL),建议直接用数据库的partitioning,如果实在不能解决你的需要,在symfony 2里可以:
用事件监听的方式,根据用户ID或其他分库条件,来修改或者动态地注册数据库连接实例。
或者简单点,就自己注册多个连接实例,然后定义一个获取所需实例的helper,比如按用户ID来分库:
// (一)在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(); // 这时拿到的就是对应当前用户的数据库连接实例了
// ...
}
在你的业务代码中,你还得考虑分片化后业务的完整性。
和传统的不一样
推荐阅读
-
symfony2 doctrine 如何分库分表
-
使用 doctrine orm 如何在程序逻辑上实现在一张表完成两个外键的设置(或则说一个实体完成两个多对一的关系)?
-
MySQL分库分表与水平分割取模案例
-
小弟我一个表A里有地个字段a b,现在数据有一部分存反了。 如何换过来
-
日志入库+分库分表(ShardingSphere) 分库分表logshardingsphere
-
简单易懂的MyBatis分库分表方案分享
-
MYSQL性能优化分享(分库分表)
-
MYSQL数据库数据拆分之分库分表总结
-
MYSQL性能优化分享(分库分表)
-
.NET Core实现分表分库、读写分离的通用 Repository功能