thinkphp项目中使用分表的思路(适用于大数据)
2017-06-30
后端
思路: 公司表中增加分表的字段 table_name 用来存分表表名
例如 公司表id % 50 = 分表id 使用封装函数getSubTable
员工表,文章表等,数据量大的需要分表的,都使用50个人分表
当添加数据到这些表的话就使用getSubTable函数来获取分表表名
//表名设计 tp_page_view_1 到 tp_page_view_50 这样
例如 $mPageView = M(getSubTable('PageView'));
$count = $mPageView->where('company_id=152')->count();
例如 公司表id % 50 = 分表id 使用封装函数getSubTable
员工表,文章表等,数据量大的需要分表的,都使用50个人分表
当添加数据到这些表的话就使用getSubTable函数来获取分表表名
//表名设计 tp_page_view_1 到 tp_page_view_50 这样
例如 $mPageView = M(getSubTable('PageView'));
$count = $mPageView->where('company_id=152')->count();
/**
* 获得分表名
* @param $tableName 基础表名
*/
function getSubTable($tableName, $companyId = null)
{
// 每张表中放50个集团的数据
$table_user = 50;
//确定 companyInfo数组
if (null === $companyId) //未指定,根据session取
{
$companyInfo = M('Company')->find(COMPANY_ID);
}
else
{
$mCompany = M('Company');
$companyInfo = $mCompany->where('id = ' . $companyId)->find();
}
//公司信息中 指定了table_name,直接取出返回
if (isset($companyInfo['table_name']) && $companyInfo['table_name'] != '')
{
return $tableName . '_' . $companyInfo['table_name'];
}
//公司信息不存在直接返回表名
if (!$companyInfo)
{
return $tableName;
}
//company表未指定id,按算法返回表名 (公司id % 50) = 分表id
$total = $companyInfo['id'] % $table_user;
//短路模式 当前面的 $total === 0 为真时候 $total = 1
$total === 0 && $total =1;
return $tableName . '_' . $total;
}