实例说明optimize table在优化mysql时很重要

今天在看CU的时候,发现有人问有关optimize来表优化的问题,当年因为这个问题,困扰我很长一段时间,今天有空我把这个问题,用实际数据来展示出来,让大家可以亲眼来看看,optimize table的重要作用,而不是似是而非的估计了。

一,原始数据

1,数据量

1
2
3
4
5
6
7
mysql> select count(*) as total from ad_visit_history;  
+---------+
| total |
+---------+
| 1187096 | //总共有118万多条数据
+---------+
1 row in set (0.04 sec)

2,存放在硬盘中的表文件大小

1
2
3
4
[root@BlackGhost test1]# ls |grep visit |xargs -i du {}  
382020 ad_visit_history.MYD //数据文件占了380M
127116 ad_visit_history.MYI //索引文件占了127M
12 ad_visit_history.frm //结构文件占了12K

Read More

session_start()导致history.go(-1)返回时无法保存表单数据的解决方法

问题背景:

在填写完表单提交时,由于某个表单项可能填写的不合法,导致提交失败,返回表单页面。但返回后所有的表单都被清空了,重新填写比较麻烦,度娘解释说,是由于每个页面都调用了session_start()的原因,在js返回上一页时,不能保存住表单信息。

解决方法:

在公共初始化文件的session_start()之后加入一句:
header(‘cache-control:private,must_revalidate’)

或:

session_cache_limiter(‘private’)

Read More

修复PHP支持的标准JSON数据格式

PHP的json_decode无法解析的JSON数据,代码如下:

1
2
$json = "{rst:5,c:[ [1018485,2,0,0,0,0,'','0-0','','',2,0,2],[1049809,17,0,0,0,0,'','','','',1,0,1],[1049813,17,0,0,0,0,'','','','',1,0,1],[1049810,17,0,0,0,0,'','','','',1,0,1]],fn:135388}";
echo json_decode($json);

//结果输出: null

Read More

assert函数的用法

assert这个函数在php语言中是用来判断一个表达式是否成立。返回true or false;
例如:

1
2
3
4
<?php  
$s = 123;
assert("is_int($s)");
?>

从这个例子可以看到字符串参数会被执行,这跟eval()类似。不过eval($code_str)只是执行符合php编码规范的$code_str。
assert的用法却更详细一点。

Read More

把一维数组合并成二维数组

描述:$name数组是3个人的名字,$age数组的元素分别对应3个人的年龄,希望合并后的数组$user,它的每一个元素都是一条独立的个人信息。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<?php  
$name = array('andy','beer','candy');
$age = array(22,13,32);

$user = array();
foreach ($name as $k => $v) {
$temp = array('name'=>$v,'age'=>$age[$k]);
$user[] = $temp;
//$user['name'][] = $v;
//$user['age'][] = $age[$k];
}

var_dump($user);
/*
array (size=3)
0 =>
array (size=2)
'name' => string 'andy' (length=4)
'age' => int 22
1 =>
array (size=2)
'name' => string 'beer' (length=4)
'age' => int 13
2 =>
array (size=2)
'name' => string 'candy' (length=5)
'age' => int 32
*/
?>