Maison > développement back-end > tutoriel php > 水平分表与垂直分表 水平标尺和垂直标尺 垂直水平靠尺 水平视角和垂直视

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

WBOY
Libérer: 2016-07-29 08:55:05
original
1824 Les gens l'ont consulté

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

信息表为例:
我事先建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教程有兴趣的朋友有所帮助。

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal