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

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

PHP 8.4 带来了多项新功能、安全性改进和性能改进,同时弃用和删除了大量功能。 本指南介绍了如何在 Ubuntu、Debian 或其衍生版本上安装 PHP 8.4 或升级到 PHP 8.4

CakePHP 是 PHP 的开源框架。它的目的是使应用程序的开发、部署和维护变得更加容易。 CakePHP 基于类似 MVC 的架构,功能强大且易于掌握。模型、视图和控制器 gu

登录 CakePHP 是一项非常简单的任务。您只需使用一项功能即可。您可以记录任何后台进程(如 cronjob)的错误、异常、用户活动、用户采取的操作。在 CakePHP 中记录数据很容易。提供了 log() 函数

Visual Studio Code,也称为 VS Code,是一个免费的源代码编辑器 - 或集成开发环境 (IDE) - 可用于所有主要操作系统。 VS Code 拥有针对多种编程语言的大量扩展,可以轻松编写

CakePHP 是一个开源MVC 框架。它使开发、部署和维护应用程序变得更加容易。 CakePHP 有许多库可以减少大多数常见任务的过载。
