首頁 php教程 php手册 ThinkPHP中的分表使用

ThinkPHP中的分表使用

Jun 07, 2016 am 11:35 AM

讲讲ThinkPHP中的分表使用
数据分表

对于大数据量的应用,经常会对数据进行分表,有些情况是可以利用数据库的分区功能,但并不是所有的数据库或者版本都支持,因此我们可以利用ThinkPHP内置的数据分表功能来实现。帮助我们更方便的进行数据的分表和读取操作。

和数据库分区功能不同,内置的数据分表功能需要根据分表规则手动创建相应的数据表。

在需要分表的模型中定义partition属性即可。

protected $partition = array(
'field' => 'name',// 要分表的字段 通常数据会根据某个字段的值按照规则进行分表
'type' => 'md5',// 分表的规则 包括id year mod md5 函数 和首字母
'expr' => 'name',// 分表辅助表达式 可选 配合不同的分表规则
'num' => 'name',// 分表的数目 可选 实际分表的数量
);
定义好了分表属性后,我们就可以来进行CURD操作了,唯一不同的是,获取当前的数据表不再使用getTableName方法,而是使用getPartitionTableName方法,而且必须传入当前的数据。然后根据数据分析应该实际操作哪个数据表。因此,分表的字段值必须存在于传入的数据中,否则会进行联合查询。

这是tp3.2.3官方文档介绍的,对于还未阅读tp源代码的coder,光看这几句话其实是很难理解如何在tp中使用分表技术的。之前我有专门了解过分表原理,再结合tp的源代码,我和分享一下我是怎么使用tp中的分表。
一、准备工作
1、安装最新的tp3.2.3框架 http://thinkphp.cn/down/framework.html
2、按自己的喜欢新建测试数据库(例如: thinkphp),接下来建表,因为我只需要完成功能演示就行,因此我就简单地建了tp_user、tp_blog_1、tp_blog_2。表结构如下:
表user:
id: 用户id, 自增,我们blog分表就是根据这个id去定位表的;
username: 账号

表tp_blog_1:
id: 博客id, 自增
uid: 作者用户 id
title: 标题
content: 内容

表tp_blog_2和表tp_blog_1一样
可以发现,我们是对blog表进行了分表操作,表的数量是2。
手动添加一些user表数据,演示要用到。

二、核心部分:建立模型
user表的模型和正常情况一样,这里不作说明。
重点在于blog表的模型,我直接先上BlogModel:<?php <br /> namespace Home\Model;<br> use Think\Model\AdvModel;<br> class BlogModel extends AdvModel{<br> <br>    protected $tableName = 'blog';<br>    Protected $autoCheckFields = false;  //一定要关闭字段缓存,不然会报找不到表的错误<br> <br>    protected $partition = array(<br>       'field' => 'uid',// 要分表的字段 通常数据会根据某个字段的值按照规则进行分表,我们这里按照用户的id进行分表<br>       'type' => 'mod',// 分表的规则 包括id year mod md5 函数 和首字母,此处选择mod(求余)的方式<br>       'expr' => '',// 分表辅助表达式 可选 配合不同的分表规则,这个参数没有深入研究<br>       'num' => '2',// 分表的数目 可选 实际分表的数量,在建表阶段就要确定好数量,后期不能增减表的数量<br>    );<br> <br>     /**<br>      * 计算在哪张表<br>      * @param array $data<br>      * @return \Think\Model<br>      */<br>    public function computeTable($data = []){<br>       $data = empty($data) ? $_POST : $data;<br>       $table = $this->getPartitionTableName($data);<br>       return $this->table($table);<br>    }这样我们的分表模型就可以工作了,接下来进行增删改查的演示操作。

三、演示
1、插入数据:
在BlogModel中新增函数addOne:/**<br>  * 添加一条数据<br>  * @param array $data<br>  * @return bool|int<br>  */<br> public function addOne($data=[]){<br>     if(empty($data[$this->partition['field']])){<br>         E('缺少' . $this->partition['field']);<br>     }<br>     $data['id'] = intval($this->computeTable()->max('id')) + 1;<br>     if($this->create($data)){<br>         $id = $this->computeTable($data)->add();<br>         if($id === false){<br>             $this->error = '插入数据错误';<br>             return false;<br>         }else{<br>             return $data['id'];<br>         }<br>     }<br>     return false;<br> } 在Home/Controller/IndexController文件新增操作addBlog:/**<br>  * 新增数据演示<br>  */<br> public function addBlog($uid=1){<br>     $blogM = D('Blog');<br>     for($i=1; $i          $this->show("<br>添加第{$i}条数据<br>");<br>         $data = ['title'=>'标题'.$i, 'content'=>'内容内容', 'uid'=>$uid];<br> <br>         $result = $blogM->addOne($data);<br>         if($result !== false){<br>             $this->show('插入数据后的id为:'.$result);<br>         }else{<br>             $this->show('插入数据失败,失败原因:'.$blogM->getError());<br>         }<br>     }<br> <br> }打开浏览器访问: 域名/index.php?s=/home/index/addBlog/uid/1 ,可以自行核对是否达到预期的效果。

2、获取所有博客:
在BlogModel中新增函数getAll:/**<br>  * 获取所有记录<br>  */<br> public function getAll(){<br> <br>     return $this->computeTable()->select();<br> }在Home/Controller/IndexController文件新增操作getBlogs:/**<br>  * 获取所有数据演示<br>  */<br> public function getBlogs(){<br>     $blogM = D('Blog');<br>     $list = $blogM->getAll();<br>     dump($list);<br> }浏览器访问: 域名/index.php?s=/home/index/getBlogs,可以自行核对是否达到预期的效果。

3、根据条件获取多条数据
在BlogModel中新增函数getList:/**<br>  * 条件查询列表<br>  * @param $map<br>  * @return mixed<br>  */<br> public function getList($map){<br>     if(empty($map[$this->partition['field']])){<br>         E('缺少' . $this->partition['field']);<br>     }<br> <br>     return $this->computeTable($map)->where($map)->select();<br> }在Home/Controller/IndexController文件新增操作getBlogByUid:/**<br>  * 根据条件查询数据演示<br>  * @param int $uid<br>  */<br> public function getBlogsByUid($uid = 1){<br>     $blogM = D('Blog');<br>     $list = $blogM->getList(['uid' => $uid]);<br>     dump($list);<br> }浏览器访问: 域名/index.php?s=/home/index/getBlogsByUid/uid/1,可以自行核对是否达到预期的效果。

4、查询单条记录
在BlogModel中新增函数getOne:/**<br>  * 根据查询条件获取一条记录<br>  * @param $map<br>  * @return mixed<br>  */<br> public function getOne($map){<br>     if(empty($map[$this->partition['field']])){<br>         E('缺少' . $this->partition['field']);<br>     }<br>     return $this->computeTable($map)->where($map)->find();<br> }在Home/Controller/IndexController文件新增操作blogDetail:/**<br>  * 查询一条数据演示<br>  * @param int $uid<br>  * @param int $blog_id<br>  */<br> public function blogDetail($uid = 1, $blog_id=1){<br>     $blogM = D('Blog');<br>     $data = $blogM->getOne(['uid' => $uid, 'id' => $blog_id]);<br>     dump($data);<br> }浏览器访问: 域名/index.php?s=/home/index/blogdetail/uid/1/blog_id/1,可以自行核对是否达到预期的效果。

5、更新一条记录
在BlogModel中新增函数updateOne:/**<br>  * 更新一条记录<br>  * @param $map<br>  * @param $data<br>  * @return bool<br>  */<br> public function updateOne($map, $data){<br>     if(empty($map[$this->partition['field']])){<br>         E('缺少' . $this->partition['field']);<br>     }<br>     if($this->create($data)){<br>         $res = $this->computeTable($map)->save($data);<br>         if($res === false){<br>             $this->error = '更新数据出错';<br>         }else{<br>             return $res;   //更新的数据条数<br>         }<br>     }<br>     return false;<br> }在Home/Controller/IndexController文件新增操作updateBlog:/**<br>  * 更新一条记录演示<br>  * @param int $uid<br>  * @param int $blog_id<br>  */<br> public function updateBlog($uid=1, $blog_id=1){<br>     $blogM = D('Blog');<br>     $map = ['uid'=>$uid, 'id'=>$blog_id];<br>     $this->show("id为".$blog_id."的博客在修改之前为<br>");<br>     $blog = $blogM->getOne($map);<br>     dump($blog);<br> <br>     $this->show("id为".$blog_id."的博客在修改之后为<br>");<br>     $data = ['title' => '我被修改了', 'id' => $blog_id];<br>     $res = $blogM->updateOne(['uid' => $uid], $data);<br>     if($res === false){<br>         dump($blogM->getError());<br>     }else{<br>         $blog = $blogM->getOne($map);<br>         dump($blog);<br>     }<br> }浏览器访问: 域名/index.php?s=/home/index/updateblog/uid/1/blog_id/1,可以自行核对是否达到预期的效果。

6、删除一条数据
在BlogModel中新增函数delOne:/**<br>  * 删除一条记录<br>  * @param $map<br>  * @return bool|mixed<br>  */<br> public function delOne($map){<br>     if(empty($map[$this->partition['field']])){<br>         E('缺少' . $this->partition['field']);<br>     }<br>     $res = $this->computeTable($map)->where($map)->delete();<br>     if($res === false){<br>         $this->error = '删除数据出错';<br>         return false;<br>     }else{<br>         return $res;   //删除数据个数<br>     }<br> }在Home/Controller/IndexController文件新增操作delBlog:/**<br>  * 删除一条数据演示<br>  * @param int $uid<br>  * @param int $blog_id<br>  */<br> public function delBlog($uid = 1, $blog_id=1){<br>     $blogM = D('Blog');<br>     $map = ['uid' => $uid, 'id' => $blog_id];<br>     $this->show("准备要删除的博客<br>");<br>     dump($blogM->getOne($map));<br> <br>     $this->show("删除结果<br>");<br>     $res = $blogM->delOne($map);<br>     dump($res);<br> }浏览器访问: 域名/index.php?s=/home/index/delblog/uid/1/blog_id/1,可以自行核对是否达到预期的效果。

以上只例举了一些其他操作,其他tp模型具有的操作可以举一反三得到,希望各自去使用。

AD:真正免费,域名+虚机+企业邮箱=0元

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

了解Python編程的入門級程式碼範例 了解Python編程的入門級程式碼範例 Jan 04, 2024 am 10:50 AM

了解Python編程的入門級程式碼範例

PHP 變數的實際應用:10 個實際使用範例 PHP 變數的實際應用:10 個實際使用範例 Feb 19, 2024 pm 03:00 PM

PHP 變數的實際應用:10 個實際使用範例

從入門到精通:Go語言中常用資料結構的程式碼實現 從入門到精通:Go語言中常用資料結構的程式碼實現 Mar 04, 2024 pm 03:09 PM

從入門到精通:Go語言中常用資料結構的程式碼實現

如何使用PHP編寫庫存管理系統中的庫存分倉管理功能代碼 如何使用PHP編寫庫存管理系統中的庫存分倉管理功能代碼 Aug 06, 2023 pm 04:49 PM

如何使用PHP編寫庫存管理系統中的庫存分倉管理功能代碼

Java實作簡單的冒泡排序程式碼 Java實作簡單的冒泡排序程式碼 Jan 30, 2024 am 09:34 AM

Java實作簡單的冒泡排序程式碼

Go語言程式設計實例:Web開發中的程式碼範例 Go語言程式設計實例:Web開發中的程式碼範例 Mar 04, 2024 pm 04:54 PM

Go語言程式設計實例:Web開發中的程式碼範例

華為雲端邊緣運算對接指南:Java程式碼範例快速實作接口 華為雲端邊緣運算對接指南:Java程式碼範例快速實作接口 Jul 05, 2023 pm 09:57 PM

華為雲端邊緣運算對接指南:Java程式碼範例快速實作接口

Java 檔案操作與雲端儲存整合:探索無限可能 Java 檔案操作與雲端儲存整合:探索無限可能 Feb 27, 2024 pm 04:55 PM

Java 檔案操作與雲端儲存整合:探索無限可能

See all articles