实例
查找:根据取模查询分库数据
删除:根据取模删除分库数据,异步执行消息队列后删除总数据库数据
查询代码: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);
}