Mysql分布式之原生分库(增)06

分库

1、在一台服务器上的数据库进行分表并不是最优的选择,因为操作的数据库还是在一台上,优化的效果并不是很明显
2、分库在对多服务器上的数据库能有效的分担压力
在这里插入图片描述

实现代码

1、总库操作完毕,close()关闭总库切换分库前的必要准备操作
2、取模形式将选择需要落入的分数据库与表

<?php 
if(isset($_POST) && !empty($_POST)){
    require './RunDbPdo.php';
    extract($_POST);
    $username = isset($username)?$username:'';
    $age = isset($age)?$age:0;
    $model = new RunDbPdo();
    $model->configFile = './config/user.config.php';
    $sql = "insert into mm_user(username,age) values('{$username}','{$age}')";
    $res = $model->query($sql);
    $insert_id = $model->getLastInsId();//总库操作完毕
    $model->close();//关闭总库切换分库前的必要准备操作

    if($res){//对分库进行操作
        $d = $insert_id%2;
        $model->configFile = "./config/user{$d}.config.php";
        $_sql = "insert into mm_user{$d} (user_id,username,age) values('{$insert_id}','{$username}','{$age}')";
        $ru = $model->query($_sql);
    }
    var_dump($ru);
}


 ?>

<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta charset="utf-8">
    <title>用户管理系统</title>
    <link href="./css/property-system.css" rel="stylesheet">
    <link href="./css/operate-system.css" rel="stylesheet">
        </head>
        <body>
            <main>
                <section class="content">
                    <fieldset class="form-list-32">
                        <h3 class="operate-title-1"><i></i>添加用户信息</h3>
                        <form action="add.php" id="editFormId" method="post" autocomplete="off">
                            <ul>
                                <li><h6>用户名:</h6><aside><input type="text" name="username" class="tbox30 tbox30-6"/></aside></li>
                                <li><h6>年龄:</h6><aside><input name="age" maxlength="11" class="tbox30 tbox30-6" type="text"></aside></li>
                                <li class="agent-subbtn-wrap mt30px">
                                    <h6>&nbsp;</h6><aside><input class="btn-2" type="submit" value="提交"></aside>
                                </li>
                            </ul>

                        </form>
                    </fieldset>
                </section>
            </main>
    </body>
</html>







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值