>  기사  >  백엔드 개발  >  ThinkPHP(백만 레벨) 데이터 테이블 기술의 예

ThinkPHP(백만 레벨) 데이터 테이블 기술의 예

WBOY
WBOY원래의
2016-07-25 08:59:461683검색
为大家说说ThinkPHP内置的分表算法处理百万级数据的例子,有需要的朋友,可以看看。

从thinkphp中抽取出来的代码,看看人家是如何实现大数据分表的。

数据表: house_member_0 house_member_1 house_member_2 house_member_3

model:

class MemberModel extends AdvModel {
protected $partition = array('field'=>'username','type'=>'id','num'=>'4');
    public function getDao($data=array()) {
        $data = empty($data) ? $_POST : $data;
        $table = $this->getPartitionTableName($data);
        return $this->table($table);
    }
}

action:

class MemberAction extends BaseAction {
    public function login() {
        if($this->isPost()) {
            $this->validToken();
            $dao = D('Member')->getDao();
            $res = $dao->where('username = '.$_POST['username'])->find();
            // output 为自定义方法
            // $isAjax - bool
            $this->output(false);
        }
        $this->display();
    }
}


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.