回复内容: 随着数据库表慢慢大起来,想考虑分表。我这边用的是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(); // 这时拿到的就是对应当前用户的数据库连接实例了 // ...}
在你的业务代码中,你还得考虑分片化后业务的完整性。
和传统的不一样
