仓酷云
标题:
PHP网站制作之ThinkPHP处置海量数据分表机制具体代码...
[打印本页]
作者:
逍遥一派
时间:
2015-2-3 23:39
标题:
PHP网站制作之ThinkPHP处置海量数据分表机制具体代码...
熟悉了PHP和MYSQL开发的要领之后,再回头看你写的那个留言本,你也许会怀疑那真的是你写的吗?当然,如果屋里还有鬼的话,也许是它写的-_- 使用ThinkPHP内置的分表算法处置百万级用户数据.
数据表:
house_member_0
house_member_1
house_member_2
house_member_3
模子中
class MemberModel extends AdvModel {
protected $partition = array('field'=>'username','type'=>'id','num'=>'4');
public function getDao($data=array()) {
$data = empty($data) ? $_POST : $data;
$table = $this->getPartitionTableName($data);
return $this->table($table);
}
}
办法中
class MemberAction extends BaseAction {
public function login() {
if($this->isPost()) {
$this->validToken();
$dao = D('Member')->getDao();
$res = $dao->where('username = '.$_POST['username'])->find();
// output 为自界说办法
// $isAjax - bool
$this->output(false);
}
$this->display();
}
}
/**
+----------------------------------------------------------
* 失掉分表的的数据表名
+----------------------------------------------------------
* @access public
+----------------------------------------------------------
* @param array $data 操作的数据
+----------------------------------------------------------
* @return string
+----------------------------------------------------------
*/
public function getPartitionTableName($data=array()) {
// 对数据表停止分区
if(isset($data[$this->partition['field']])) {
$field = $data[$this->partition['field']];
switch($this->partition['type']) {
case 'id':
// 依照id局限分表
$step = $this->partition['expr'];
$seq = floor($field / $step)+1;
break;
case 'year':
// 依照年份分表
if(!is_numeric($field)) {
$field = strtotime($field);
}
$seq = date('Y',$field)-$this->partition['expr']+1;
break;
case 'mod':
// 依照id的模数分表
$seq = ($field % $this->partition['num'])+1;
break;
case 'md5':
// 依照md5的序列分表
$seq = (ord(substr(md5($field),0,1)) % $this->partition['num'])+1;
break;
default :
if(function_exists($this->partition['type'])) {
// 撑持指定函数哈希
$fun = $this->partition['type'];
$seq = (ord(substr($fun($field),0,1)) % $this->partition['num'])+1;
}else{
// 依照字段的首字母的值分表
$seq = (ord($field{0}) % $this->partition['num'])+1;
}
}
return $this->getTableName().'_'.$seq;
}else{
// 当设置的分表字段不在查询前提或数据中
// 停止结合查询,必需设定 partition['num']
$tableName = array();
for($i=0;$i<$this->partition['num'];$i++)
$tableName[] = 'SELECT * FROM '.$this->getTableName().'_'.$i;
$tableName = '( '.implode(" UNION ",$tableName).') AS '.$this->name;
return $tableName;
}
}
<P style="TEXT-INDENT: 2em">
要想从事软件开发工作,那么,还有很多的知识要学习,其实,不管是以后想去从事哪个工作,都需要自己去利用空闲的时间去不断的学习新的知识,不断的充实自己。
作者:
透明
时间:
2015-2-4 05:01
,熟悉html,能用div+css,还有javascript,优先考虑linux。我在开始学习的时候,就想把这些知识一起学习,我天真的认为同时学习能够互相呼应,因为知识是相通的。
作者:
若相依
时间:
2015-2-5 00:49
如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了,
作者:
admin
时间:
2015-2-5 04:21
开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。
作者:
活着的死人
时间:
2015-2-7 05:06
我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。
作者:
冷月葬花魂
时间:
2015-2-20 14:24
首先我是坚决反对新手上来就用框架的,因为对底层的东西一点都不了解,造成知识上的真空,会对以后的发展不利。我的观点上手了解下框架就好,代码还是手写。当然啦如果是位别的编程语言的高手的话,这个就另当别论啦。
作者:
老尸
时间:
2015-3-6 18:18
使用 jquery 等js框架的时候,要随时注意浏览器的更新情况,不然很容易发生框架不能使用。
作者:
兰色精灵
时间:
2015-3-13 05:08
当然这种网站的会员费就几十块钱。
作者:
若天明
时间:
2015-3-13 05:08
有时候汉字的空格也能导致页面出错,所以在写代码的时候,要输入空格最好用引文模式。
作者:
若天明
时间:
2015-3-13 05:08
因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax
作者:
第二个灵魂
时间:
2015-3-13 05:08
使用zendstdio 写代码的的时候,把tab 的缩进设置成4个空格是很有必要的
作者:
再见西城
时间:
2015-3-13 08:08
首先我是坚决反对新手上来就用框架的,因为对底层的东西一点都不了解,造成知识上的真空,会对以后的发展不利。我的观点上手了解下框架就好,代码还是手写。当然啦如果是位别的编程语言的高手的话,这个就另当别论啦。
作者:
愤怒的大鸟
时间:
2015-3-17 16:54
我还是强烈建议自己搭建php环境。因为在搭建的过程中你会遇到一些问题,通过搜索或是看php手册解决问题后,你会更加深刻的理解它们的工作原理,了解到php配置文件中的一些选项设置。
作者:
小妖女
时间:
2015-3-19 13:58
个人呢觉得,配wamp 最容易漏的一步就是忘了把$PHP$目录下的libmysql.dll拷贝到windows系统目录的system32目录下,还有重启apache。
作者:
爱飞
时间:
2015-3-23 02:40
使用zendstdio 写代码的的时候,把tab 的缩进设置成4个空格是很有必要的
作者:
乐观
时间:
2015-4-11 03:38
曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线 \\\\\\\'_\\\\\\\' ;
作者:
灵魂腐蚀
时间:
2015-4-16 12:09
微软最近出的新字体“微软雅黑”,虽然是挺漂亮的,不过firefox 支持的不是很好,所以能少用还是少用的好。
作者:
小女巫
时间:
2015-4-26 03:08
建数据库表的时候,int型要输入长度的,其实是个摆设的输入几位都没影响的,只要大于4就行,囧。
作者:
深爱那片海
时间:
2015-4-30 14:24
php里的数组为空的时候是不能拿来遍历的;(这个有点低级啊,不过我刚被这个边界问题墨迹了好长一会)
作者:
只想知道
时间:
2015-5-5 04:19
有位前辈曾经跟我说过,phper 至少要掌握200个函数 编起程序来才能顺畅点,那些不熟悉的函数记不住也要一拿手册就能找到。所以建议新手们没事就看看php的手册(至少array函数和string函数是要记牢的)。
作者:
简单生活
时间:
2015-6-12 22:23
首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。
欢迎光临 仓酷云 (http://ckuyun.com/)
Powered by Discuz! X3.2