分库
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> </h6><aside><input class="btn-2" type="submit" value="提交"></aside>
</li>
</ul>
</form>
</fieldset>
</section>
</main>
</body>
</html>