Mysql分布式之原生分库(查、删)08

实例

查找:根据id取模查询对应分库分表数据
删除:根据取模删除分库数据,异步执行消息队列后删除总数据库数据

查询代码:find.php

<?php
require "./RunDbPdo.php";
$model = new RunDbPdo();
$model->configFile = './config/user.config.php';

$user_id = 2;
$d = $user_id % 2;
$model->configFile = "./config/user{$d}.config.php";
$sql = "select * from mm_user{$d} where user_id='{$user_id}'";
$data = $model->getRow($sql);
var_dump($data);

删除逻辑代码delete.php

<?php
require "./RunDbPdo.php";
require './RedisQ.php';

$model = new RunDbPdo();
$model->configFile = './config/user.config.php';
$redis = new RedisQ();

#1、先删除分库数据,后压入消息队列删除总库数据
$user_id = 3;
$d = $user_id % 2;
$model->configFile = "./config/user{$d}.config.php";
$sql = "delete from mm_user{$d} where user_id = '{$user_id}'";
$result = $model->query($sql);
if ($result) {
    $sql = "delete from mm_user where user_id = '{$user_id}'";
    $bool = $redis->lpush('sqls', $sql);
    var_dump($bool);
}

异步执行消息队列删除总库数据queque.php

<?php
$file_dir = dirname(__FILE__);
chdir($file_dir);
require "./RedisQ.php";
require './RunDbPdo.php';

$redis_boj = new RedisQ();
$model = new RunDbPdo();
$model->configFile = './config/user.config.php';

//4、循环出队列  当sql为空时break结束前循环,sql执行失败的写入文件日志,后期重新执行
$do = true;
while ($do) {
    $sql = $redis_boj->rpop('sqls');
    if(empty($sql)){
        break;
    }
    $res = $model->query($sql);
    if(!$res){
        file_put_contents('sql_push',$sql);
    }
    var_dump($res);
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值