tp5mysql分表_基于ThinkPHP5.1扩展的分布式分表数据库存储架构,开贴记录下相关重要代码...

本文介绍了基于ThinkPHP5.1的分布式分表存储架构,核心涉及PHP分表存储、主从复制和合表查询分页。通过SubTable类实现分表,使用Snowflake类生成分布式服务器唯一ID。文章提供了关键代码示例,包括分表存储、表结构同步更新和合表分页查询的方法。
摘要由CSDN通过智能技术生成

基于ThinkPHP5.1扩展的分布式分表数据库存储架构,开贴记录下相关重要代码

6cd5e4fd49658da7be73f2e8e3760c00.png

1年前

阅读 6695

评论 0

喜欢 4

### 核心技术

1、PHP分表存储

2、分布式服务器(数据库),主从复制

3、合表查询分页

### 分表存储代码

```php

namespace org;

class SubTable

{

// 缓存表名称地址

protected static $table_path = '';

// 缓存表名称列表

protected static $table_list = [];

// 表前缀

private static $prefix = 'tp_';

// 表中缀:TP的分表链接只能是下划线中缀

private static $in_prefix = '_';

// 表名称

private static $table = '';

// 单例实例

private static $instance;

// 私有化构造函数,可以保证在类外该类不能被实例化

private function __construct(){}

// 禁止克隆单例类,防止二次new

private function __clone()

{

die('此对象不允许被克隆');

}

/**

* 用于初始化单例类

* @todo 无

* @author 小黄牛

* @version v1.0.1 + 2019.05.23

* @deprecated 暂不弃用

* @global 无

* @param string $table

* @return void

*/

public static function init($table)

{

self::$table = $table;

if (!self::$instance instanceof self) {

// 生成缓存地址

self::$table_path = ROOT_PATH . DIRECTORY_SEPARATOR .'public'. DIRECTORY_SEPARATOR .'data'. DIRECTORY_SEPARATOR .'table_cache' . DIRECTORY_SEPARATOR . $table . '_cache.php';

// 获得单例

self::$instance = new self();

// 返回单例

return self::$instance;

}

return self::$instance;

}

/**

* 简单hash算法,生成表名

* @todo 无

* @autho

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值