搜索
系统检测到您的用户名不符合规范:

TP5.1分表,partition分表

浏览:3638 发布日期:2020年01月06日 分类:业务逻辑 关键字: partition 分表
TP5.1分表,partition分表实例,根据非主键水平分表
模型<?php
namespace app\common\model;

use think\Model;

class WalletLog extends Model
{
protected $table = 'tb_walletlog';
protected $pk = 'walletid';

private function getRule(){
return [
'type' => 'mod', // 分表方式
'num' => 3 // 分表数量
];
}

public function saveData($data, $user_id){

return $this->partition(['user_id' => $user_id], "user_id", $this->getRule())->insert($data);
}

public function getAll($where, $field = "*", $user_id){
return $this->partition(['user_id' => $user_id], "user_id", $this->getRule())->where($where)->field($field)->select();
}
}
控制器//分表测试
public function walletSave(){
$WalletLogModel = new WalletLog();

for($i = 1; $i < 1000; $i++){
$data = [
'user_id' => $i,
'add_time' => time(),
'type' => 1,
'num' => 1
];
$WalletLogModel->saveData($data, $i);
}
echo 'success';die;
}
public function getWallet(){
$uid = request()->get('user_id',0);
if($uid){
$WalletLogModel = new WalletLog();
$user = $WalletLogModel->getAll( ['user_id'=>$uid],'*', $uid);
return json($user);
}
}
分表设置$rule分了3个表,建表tb_walletlog_1,tb_walletlog_2,tb_walletlog_3.CREATE TABLE `tb_walletlog` (
`walletid` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '成就id',
`user_id` INT(11) NOT NULL COMMENT '用户id',
`add_time` INT(10) DEFAULT NULL COMMENT '时间',
`type` INT(1) DEFAULT NULL COMMENT '类型 1消费 2收入 3充值',
`num` DOUBLE(20,3) NOT NULL COMMENT '数量',
PRIMARY KEY (`walletid`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='记录';
根据官方文档来的,一次成功了。
评论() 相关
后面还有条评论,
评论支持使用[code][/code]标签添加代码
您需要登录后才可以评论 登录 | 立即注册
收藏
771831851
积分:3793 等级:LV4
热点推荐
(追記) (追記ここまで)
最新更新

我们

合作

网站

信息

ThinkPHP 是一个免费开源的,快速、简单的面向对象的 轻量级PHP开发框架 ,创立于2006年初,遵循Apache2开源协议发布,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长为国内最领先和最具影响力的WEB应用开发框架,众多的典型案例确保可以稳定用于商业以及门户级的开发。

AltStyle によって変換されたページ (->オリジナル) /