ThinkPHP中的分表使用
讲讲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元

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











Ketahui tentang pengaturcaraan Python dengan contoh kod pengenalan Python ialah bahasa pengaturcaraan yang mudah dipelajari tetapi berkuasa. Bagi pemula, adalah sangat penting untuk memahami contoh kod pengenalan pengaturcaraan Python. Artikel ini akan memberikan anda beberapa contoh kod konkrit untuk membantu anda bermula dengan cepat. Cetak HelloWorldprint("HelloWorld") Ini ialah contoh kod paling mudah dalam Python. Fungsi print() digunakan untuk mengeluarkan kandungan yang ditentukan

Pembolehubah PHP menyimpan nilai semasa runtime program dan sangat penting untuk membina aplikasi WEB yang dinamik dan interaktif. Artikel ini melihat secara mendalam pembolehubah PHP dan menunjukkannya dalam tindakan dengan 10 contoh kehidupan sebenar. 1. Simpan input pengguna $nama pengguna=$_POST["nama pengguna"];$passWord=$_POST["kata laluan"] Contoh ini mengekstrak nama pengguna dan kata laluan daripada penyerahan borang dan menyimpannya dalam pembolehubah untuk pemprosesan selanjutnya. 2. Tetapkan nilai konfigurasi $database_host="localhost";$database_username="username";$database_pa

Contoh kod paling ringkas bagi jenis gelembung Java ialah algoritma pengisihan biasa. Idea asasnya ialah melaraskan urutan secara beransur-ansur ke dalam urutan tersusun melalui perbandingan dan pertukaran elemen bersebelahan. Berikut ialah contoh kod Java ringkas yang menunjukkan cara melaksanakan isihan gelembung: publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

"Contoh Pengaturcaraan Bahasa Pergi: Contoh Kod dalam Pembangunan Web" Dengan perkembangan pesat Internet, pembangunan Web telah menjadi bahagian yang amat diperlukan dalam pelbagai industri. Sebagai bahasa pengaturcaraan dengan fungsi berkuasa dan prestasi unggul, bahasa Go semakin digemari oleh pembangun dalam pembangunan web. Artikel ini akan memperkenalkan cara menggunakan bahasa Go untuk pembangunan Web melalui contoh kod tertentu, supaya pembaca boleh memahami dengan lebih baik dan menggunakan bahasa Go untuk membina aplikasi Web mereka sendiri. 1. Pelayan HTTP Mudah Mula-mula, mari kita mulakan dengan a

Cara menggunakan PHP untuk menulis kod fungsi pengurusan inventori dalam sistem pengurusan inventori adalah bahagian yang amat diperlukan dalam banyak perusahaan. Bagi syarikat yang mempunyai berbilang gudang, fungsi pengurusan inventori amat penting. Dengan mengurus dan menjejak inventori dengan betul, syarikat boleh memperuntukkan inventori antara gudang yang berbeza, mengoptimumkan kos operasi dan meningkatkan kecekapan kerjasama. Artikel ini akan memperkenalkan cara menggunakan PHP untuk menulis kod bagi fungsi pengurusan gudang inventori dan memberikan anda contoh kod yang berkaitan. 1. Wujudkan pangkalan data sebelum mula menulis kod untuk fungsi pengurusan gudang inventori.

Panduan Sambungan Pengkomputeran Tepi Awan Huawei: Contoh Kod Java untuk Melaksanakan Antara Muka Dengan Pantas Dengan perkembangan pesat teknologi IoT dan peningkatan pengkomputeran tepi, semakin banyak perusahaan mula memberi perhatian kepada aplikasi pengkomputeran tepi. Huawei Cloud menyediakan perkhidmatan pengkomputeran edge, menyediakan perusahaan dengan sumber pengkomputeran yang sangat boleh dipercayai dan persekitaran pembangunan yang mudah, menjadikan aplikasi pengkomputeran tepi lebih mudah untuk dilaksanakan. Artikel ini akan memperkenalkan cara untuk melaksanakan antara muka pengkomputeran tepi Awan Huawei dengan cepat melalui kod Java. Pertama, kita perlu menyediakan persekitaran pembangunan. Pastikan anda memasang Java Development Kit (

Tajuk: Dari Permulaan hingga Penguasaan: Pelaksanaan Kod Struktur Data Yang Biasa Digunakan dalam Bahasa Go Struktur data memainkan peranan penting dalam pengaturcaraan dan merupakan asas pengaturcaraan. Dalam bahasa Go, terdapat banyak struktur data yang biasa digunakan, dan menguasai pelaksanaan struktur data ini adalah penting untuk menjadi seorang pengaturcara yang baik. Artikel ini akan memperkenalkan struktur data yang biasa digunakan dalam bahasa Go dan memberikan contoh kod yang sepadan untuk membantu pembaca daripada mula menjadi mahir dalam struktur data ini. 1. Array Array ialah struktur data asas, kumpulan daripada jenis yang sama

Panduan Menulis Kod Kaedah Isih Pemilihan Java dan Contoh Isihan pemilihan ialah algoritma pengisihan yang mudah dan intuitif Ideanya adalah untuk memilih elemen terkecil (atau terbesar) daripada elemen yang tidak diisih setiap kali dan menukarnya sehingga semua elemen diisih. Artikel ini akan menyediakan panduan menulis kod untuk pengisihan pemilihan dan melampirkan kod sampel Java tertentu. Prinsip Algoritma Prinsip asas isihan pemilihan ialah membahagikan tatasusunan yang hendak diisih kepada dua bahagian, diisih dan tidak diisih Setiap kali, elemen terkecil (atau terbesar) dipilih daripada bahagian yang tidak diisih dan diletakkan di hujung bahagian yang diisih. Ulang perkara di atas
