> php教程 > PHP源码 > thinkphp项目中使用分表的思路(适用于大数据)

thinkphp项目中使用分表的思路(适用于大数据)

PHP中文网
풀어 주다: 2016-05-26 08:19:55
원래의
1015명이 탐색했습니다.

php代码

/**
 * 获得分表名
 * @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;
}
로그인 후 복사

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