首页 > 后端开发 > php教程 > 水平分表与垂直分表 水平标尺和垂直标尺 垂直水平靠尺 水平视角和垂直视

水平分表与垂直分表 水平标尺和垂直标尺 垂直水平靠尺 水平视角和垂直视

WBOY
发布: 2016-07-29 08:55:05
原创
1823 人浏览过

近日遇到一个问题,如果数据量比较大如何进行分表?

信息表为例:
我事先建100个这样的表,message_00,message_01,message_02……….message_98,message_99.然后根据用户的ID来判断这个用户的聊天信息放到哪张表里面,你可以用hash的方式来获得,可以用求余的方式来获得,方法很多,各人想各人的吧。下面用hash的方法来获得表名:
查看复制打印?
function get_hash_table($table,$userid) {
$str = crc32($userid);
if($str$hash = '0'.substr(abs($str), 0, 1);
}else{
$hash = substr($str, 0, 2);
}
return $table.'_'.$hash;
}
echo get_hash_table('message','user18991'); //结果为message_10

这个就是获取数据表的方法

 原来的表明是写死的
你这是通过函数获取表名就可以了

 像新闻那种Cm s一半是根据分类来拆分表的,这叫垂直切分
用户那种叫水平切分 

 比如 : list 这个表 有50W条数据 , 你PHP写个判断 , 每写这表时判断一下, 是不是 达到50W条, if达到 ,就写入 list_1表 , 写个自动增加表 


然后再根据条件 查询是哪个表  然后在进行操作


以上就介绍了水平分表与垂直分表,包括了垂直,水平方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板