(最近在学习mysql优化的一些问题,以下为个人一些收获,如有不足,敬请提出!)
概述:当一个表的数据很大,比如200G,这时太大,我们只靠索引也不好使了,这时我们需要分表和分区处理。分表有两种形式(水平分表和垂直分表)。
一、水平分表
核心思想:把一个大表,分割N个小表,小表和大表结构一样,只是把数据分散到不同的表中。
1.1 简单例子:比如说是通过ID直接登录(例如QQ号),可以直接使用下面的例子
每次登录验证的时候只要把传过来的Id除3取模,根据模可以找到对应的表,然后再去对应的表做查询操作,以下为php的相关操作,注册以及登录。
register.php
<?php
//接收参数
//测试的参数有:Pwd,Name, Email
extract($_POST); //检查是否为空
if(empty($Pwd) || empty($Name) || empty($Email)){
die('参数不能为空!');
} //连接数据库
$link = mysql_connect('127.0.0.1:3306','root', 'root');
if(!$link){
die('数据库连接失败!');
} //选择数据库:这个数据库有:uuid表(产生Id的表)、User0表(存放模为0的用户信息)、User1表(存放模为1的用户信息)和User2表(存放模为2的用户信息)
mysql_select_db('test'); $sql = 'INSERT INTO uuid VALUES(null)';
if(mysql_query($sql, $link)){
//获取刚刚插入的Id
$id = mysql_insert_id(); //根据 Id%3 来确定该新用户存放的表
$table_name = 'User'.$Id%3; $pwd = md5($Pwd);
$sql = "INSERT INTO $table_name VALUES($id, $Name, $pwd, $Email )"; if(mysql_query($sql, $link)){
echo '注册成功!';
}else{
echo '注册失败!';
}
}
register.php
login.php
<?php
header("Content-Type:text/html;charset:utf-8"); //接收参数:Id, Pwd
extract($_POST); //判断是否为空
if(empty($Id) || empty($Pwd)){
die('参数不能为空!');
} //连接数据库
$link = mysql_connect('127.0.0.1:3306', 'root', 'root');
if(!$link){
die('连接失败!');
} //选择数据库
mysql_select_db('test'); $table_name = 'User'.$Id%3;
$sql = "SELECT * FROM $table_name WHERE Id = $Id";
$rst = mysql_query($sql, $link); if($row = mysql_fetch_assoc($rst)){
$db_pwd = $row['Pwd']; if($db_pwd == md5($Pwd)){
echo '登录成功!';
}else{
echo '用户名或者密码错误!';
}
}else{
echo 'Id错误!';
}
login.php
1.1 通过邮箱登录,通过邮箱对表进行分割
邮箱基本原理都是和Id差不多,就是要通过一个算法把md5字符串转成十进制的数,然后再取模,以下为把十六进制的md5字符串转成十进制的函数。